zoukankan      html  css  js  c++  java
  • 排列问题

        对给出的n个数,求出其所有的排列。

    思路:对于R={r1,r2,r3.......rn},其全排列可以这样去计算,

     perm(R)=riperm(R-ri);(1<=i<=n)

    即以ri为前缀不变,对剩下所有的元素进行排列。即分别以r1,r2,r3,....rn作为前缀不变,对剩下的所有元素进行全排列即为所得到的结果。同理对于perm(R-ri)的求解也是一个相同的过程,因此可以采用递归的思想去解决。

    #include<iostream>
    using namespace std;
    
    void swap(int &a,int &b)
    {
      int temp=a;
      a=b;
      b=temp;
    }
    
    //函数Perm(int a[],int k,int m)是求将a的第1~k-1个元素不动、第k~m个元素进行全排列得到的全排列
    void perm(int *a,int k,int m)
    {
      if(k==m) //如果前缀是最后一个位置,即只剩下一个元素了
      {
        int i;
        for(i=1;i<m;i++)
        {
          printf("%d ",a[i]);
        }
        printf("%d\n",a[i]);
      }
      else
      {
        for(int i=k;i<=m;i++)
        {
          swap(a[k],a[i]); //交换前缀
          perm(a,k+1,m);
          swap(a[k],a[i]); //产生完排列后,换回原来的位置
        }
      }
    }
    
    int main(void)
    {
      int n;
      int *a;
      while(scanf("%d",&n)==1&&n>=1)
      {
        a=(int *)malloc((n+1)*sizeof(int));
        for(int i=1;i<=n;i++)
        {
          scanf("%d",&a[i]);
        }
        perm(a,1,n);
      }
      return 0;
    }
  • 相关阅读:
    11.关于django的content_type表
    6.re正则表达式
    1.关于python 的hmac加密
    4.瀑布流js
    10.django的一些方法理解
    7.一些比较有用的网站
    准备辞职了,走之前想解决的问题ptr 为空
    Oracle 代码生成小工具免费下载
    Js 中一个判断类型的方法
    jQuery 加上最后自己的验证
  • 原文地址:https://www.cnblogs.com/dolphin0520/p/2102174.html
Copyright © 2011-2022 走看看