zoukankan      html  css  js  c++  java
  • 生成1~n的全排列

    输入正整数n,输出n的全排列。

    样例输入1:

    3

    样例输出1:

    1 2 3

    1 3 2

    2 1 3

    2 3 1

    3 1 2

    3 2 1

    分析:

    按字典序从小到大的顺序输出所有的排列。

    (字典序:两个序列的字典序大小关系等价于从头开始第一个不相同位置处的大小关系)

    使用数组a保存排列中的数,集合s代表剩下的数。

    则有

    方法1:

    1.伪代码:

    int dfs(a,s,cur){//找到排列中的第cur个数字。

    If (s==空) 输出这个排列;

    else 

      取集合s中的元素i;

      a[cur]=i  ;//存到a数组中

      dfs(a,s,cur+1);

    }

    s集合可以省掉,直接用a来表示,如果i在a[1]~a[cur-1]中存在,则说明i已经使用,否则说明i在集合s中。

    因为要从第一个数字开始找,所以首先调用dfs(1)  //cur=1

    源代码:

    #include<cstring>

    using namespace std;

    int a[100],s, n;;

    void dfs(int cur){//函数没有返回值,所以类型为void

     if (cur==n+1) {

      for (int i=1;i<n;i++) cout<<a[i]<<" ";

      cout<<a[n]<<endl;

      s++;

      }

     else for (int i=1;i<=n;i++){

         int ok=1;

             for(int j=1;j<cur;j++)  //因为当前找第cur个数字,所以和前面已经找到的cur-1个数字比较

                if(a[j]==i) ok=0;

             if (ok){ a[cur]=i ;dfs(cur+1);}

        }     

    }

    int main(){

     memset(a,0,sizeof(a));

     cin>>n;

     dfs(1);

     cout<<s<<endl;

     return 0;

    }

    思考:

    (1)全局变量与局部变量;

    比如a数组和变量n,s在main和dfs中都要用到,所以定义为全局变量,cur只在当前调用的函数中使用,所以定义为局部变量。

    (2)函数没有返回值时如何处理。

      函数没有返回值时,函数类型为void,可以没有return语句,也可以有,但其后没有表达式

         return ;

    2.

    伪代码:

    int dfs(cur){//已经找到cur个数字,准备找下一个。

    If (s==空) 输出这个排列;

    else 

      取集合s中的元素i;

      a[cur+1]=i  ;//存到a数组中

      dfs(cur+1);

    }

    初始时已经找到了0个数字,所以首先调用dfs(0)

     1 #include<iostream>
     2 #include<cstring>
     3 using namespace std;
     4 int a[100],s=0, n;
     5 void dfs(int cur){//函数没有返回值时类型为void
     6     if (cur==n) {
     7         for (int i=1;i<n;i++) cout<<a[i]<<" ";
     8         cout<<a[n]<<endl;
     9         s++;
    10     }
    11     else
    12          for (int i=1;i<=n;i++){
    13               int ok=1;
    14               for(int j=1;j<=cur;j++)
    15                     if(a[j]==i) ok=0;
    16               if (ok){
    17                   a[cur+1]=i;        
    18                   dfs(cur+1);              
    19             }
    20           }      
    21 }
    View Code
    //使用标记数组
    #include<iostream>
    #include<cstdio>
    using namespace std;
    int a[100],f[100] ;
    int n;
    void dfs(int cur){
        if (cur==n) {
            for (int i=1;i<n;i++) printf("%d ",a[i]);
            printf("%d
    ",a[n]);
            return ;
        }
        for (int i=1;i<=n;i++)
            if (!f[i]){
                a[cur+1]=i;
                f[i]=1; //标记i已经使用 
                dfs(cur+1);
                f[i]=0;
                
            }
    }
    int main(){
        scanf("%d",&n);
        for (int i=1;i<=n;i++) f[i]=0;//f初值为0
        dfs(0);
        return 0;
    }
    View Code

    #include<iostream>
    #include<algorithm>
    #include<cstdio>
    using namespace std;
    int a[100],p[100] ;
    int n;
    int main(){
        cin>>n;
        for (int i=1;i<=n;i++) a[i]=i;//初值为最小的字母表顺序
        do{
            for (int i=1;i<n;i++) printf("%d ",a[i]);
            printf("%d
    ",a[n]);
        }while (next_permutation(a+1,a+n+1));
        return 0;
    }

    参考网址:http://codevs.cn/problem/1294/

    该题目卡cin,cout(第五个点过不了),使用scanf和printf就没有问题了。 

  • 相关阅读:
    应用上架前如何知道自己应用的下载地址?
    Multi-line NSAttributedString with truncated text
    Adding AirDrop File Sharing Feature to Your iOS Apps
    Add sharing to your app via UIActivityViewController
    [原]iOS自带社会化分享框架——Social.framework
    xcode 制作静态库.a文件 详解
    Fiddler怎么对IPhone手机的数据进行抓包分析
    Mac上的抓包工具Charles
    30、准确计算CoreText高度的方法
    keil MDK中如何生成*.bin格式的文件
  • 原文地址:https://www.cnblogs.com/ssfzmfy/p/4638507.html
Copyright © 2011-2022 走看看