• 全排列(传统&&黑科技)


    近期几次考试的一些题目暴力分都有用到全排列。

    全排列是个好东西啊...

    回想一下,我们最开始学到全排列是什么时候呢?

    大概是学搜索的时候罢...

    一、传统搜索算法

    想复习可以戳 https://www.luogu.org/problemnew/show/P1706

     1 #include<iostream>
     2 #include<cstdlib>
     3 #include<cstdio>
     4 #include<iomanip> 
     5 using namespace std;
     6 int num=0,a[15]={0},n,r;
     7 bool b[15]={0};
     8 int search(int);
     9 int print();
    10 int main(){
    11     cin>>n;
    12     search(1);
    13     cout<<num<<endl;
    14     system("pause");
    15     return 0;
    16     }
    17 int search(int k)//k是找第几位数 
    18 {  for(int i=1;i<=n;i++)
    19    if(!b[i])
    20    {  a[k]=i;
    21       b[i]=1;
    22       if(k==n)print();
    23        else search(k+1);
    24          b[i]=0;}
    25 }
    26 int print()
    27   { num++;
    28     for(int i=1;i<=n;i++)
    29     cout<<a[i];
    30     cout<<endl;
    31 }
    View Code

    二、利用万能的STL<algorithm>模板库

    一个函数:next_permutation()

    代码就是:

     1 #include<algorithm>
     2 #include<cstdio>
     3 using namespace std;
     4 int a[8]={1,2,3,4,5,6,7};
     5 int n;
     6 int main()
     7 {
     8     scanf("%d",&n);
     9     do{
    10         for(int i=0;i<n;i++)
    11         {
    12             printf("%d",a[i]);
    13         }
    14         printf("
    ");
    15     }while(next_permutation(a,a+n));
    16     return 0;
    17 }
    View Code
  • 相关阅读:
    我所认识的JavaScript
    谈如何边做事,边提高
    对JavaScript开发中困扰的思考
    Soundex语音算法
    Perl分割字符串的一个精妙的写法
    Perl深拷贝
    Git diff hash顺序的问题
    perl命令行批量修改文件内容
    IOS写文件
    删除Linux乱码文件
  • 原文地址:https://www.cnblogs.com/nopartyfoucaodong/p/8995722.html
Copyright © 2020-2023  润新知