zoukankan      html  css  js  c++  java
  • 求全排列算法简单的实现

    求全排列算法实现(一)递归实现

    假如是一个数组,无重复元素的全排列,其简单的递归实现算法思想如下:

    假如:allsort(a b c);分治思想化为a+allsort(b c); b+allsort(a c), c+allsort(a b);

    递归一层后计算第二层时:如allsort(b c)时,化为b+allsort(c) 和 c+allsort(b);

    此时问题就明显了,首先确定一个元素,求剩下的全排列,如此类推下去做一个递归;

    c++实现了一个简单的代码如下:

     1 #include <iostream>
     2 using namespace std;
     3 void swap(int &a,int &b)//交换连个元素
     4 {
     5     int tem;
     6     tem = a;
     7     a = b;
     8     b = tem;
     9 }
    10 void cal(int *a,int first,int length)
    11 {
    12     if(first == length)//如果递归到深层时,到最后交换的元素即时最后一个元素时就打印出来
    13     {
    14         for(int i = 0; i <= length; i++)
    15         cout<<a[i]<<" ";
    16         cout<<endl;
    17     }
    18     else
    19     {
    20         for(int i = 0; i <= length; i++)
    21         {//循环遍历使得当前位置后边的每一个元素都和当前深度的第一个元素交换一次
    22             swap(a[first],a[i]);//使得与第一个元素交换
    23             cal(a,first+1,length);//深入递归,此时已确定前边的元素,处理后边子序列的全排列形式。
    24             swap(a[first],a[i]);//恢复交换之前的状态
    25         }
    26     }
    27 }
    28 int main()
    29 {
    30     int a[3] = {1,2,3};
    31     cal(a,0,2);
    32     return 0;
    33 }

    全排列的递归实现似乎效率有些低。不过这个思路比较清晰。易理解,首先看会了递归的实现,再进一步的研究如何实现非递归求全排列的方法。

  • 相关阅读:
    图片加载框架之Glide和Picasso
    图片加载框架之fresco
    图片加载框架之ImageLoader
    依赖注入框架之androidannotations
    依赖注入框架之butterknife
    Android依赖注入框架之Dagger2
    EvenBus源码分析
    时间总线框架之EvenBus
    数据库开源框架之litepal
    数据库开源框架之sqlcipher加密数据库
  • 原文地址:https://www.cnblogs.com/newpanderking/p/2494549.html
Copyright © 2011-2022 走看看