排列问题

[复制链接]
260|0
 楼主| programmable 发表于 2019-9-14 18:22 | 显示全部楼层 |阅读模式
    对给出的n个数,求出其所有的排列。
思路:对于R={r1,r2,r3.......rn},其全排列可以这样去计算,
perm(R)=riperm(R-ri);(1<=i<=n)
即以ri为前缀不变,对剩下所有的元素进行排列。即分别以r1,r2,r3,....rn作为前缀不变,对剩下的所有元素进行全排列即为所得到的结果。同理对于perm(R-ri)的求解也是一个相同的过程,因此可以采用递归的思想去解决。

  1. #include<iostream>
  2. using namespace std;

  3. void swap(int &a,int &b)
  4. {
  5.   int temp=a;
  6.   a=b;
  7.   b=temp;
  8. }

  9. //函数Perm(int a[],int k,int m)是求将a的第1~k-1个元素不动、第k~m个元素进行全排列得到的全排列
  10. void perm(int *a,int k,int m)
  11. {
  12.   if(k==m) //如果前缀是最后一个位置,即只剩下一个元素了
  13.   {
  14.     int i;
  15.     for(i=1;i<m;i++)
  16.     {
  17.       printf("%d ",a[i]);
  18.     }
  19.     printf("%d\n",a[i]);
  20.   }
  21.   else
  22.   {
  23.     for(int i=k;i<=m;i++)
  24.     {
  25.       swap(a[k],a[i]); //交换前缀
  26.       perm(a,k+1,m);
  27.       swap(a[k],a[i]); //产生完排列后,换回原来的位置
  28.     }
  29.   }
  30. }

  31. int main(void)
  32. {
  33.   int n;
  34.   int *a;
  35.   while(scanf("%d",&n)==1&&n>=1)
  36.   {
  37.     a=(int *)malloc((n+1)*sizeof(int));
  38.     for(int i=1;i<=n;i++)
  39.     {
  40.       scanf("%d",&a[i]);
  41.     }
  42.     perm(a,1,n);
  43.   }
  44.   return 0;
  45. }


作者:Matrix海子
    出处:http://www.cnblogs.com/dolphin0520/
    本博客中未标明转载的**归作者Matrix海子和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在**页面明显位置给出原文连接,否则保留追究法律责任的权利。

您需要登录后才可以回帖 登录 | 注册

本版积分规则

28

主题

394

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部