标签:算法
生成排列
生成排列即对n个数的全排列,显然时间复杂度是n指数级的O(n^k)
假定可以生成n-1个数的所有排列,那么就可以扩展生成1,2,.....,n的排列。
例如1的生成排列即1
1,2的生成排列即1,2和2,1
1,2,3的生成排列在1,2的生成排列基础上可以这样得到:
1在第1位,2,3的生成排列
2在第1位,1,3的生成排列
3在第1位,2,3的生成排列
那么推广到1,2,...,n的生成排列即:
1在第1位,2,...,n的生成排列
2在第2位,1,3,...n的生成排列
....
n在第1位,2,...,n的生成排列
先考虑数字1在第一位,那么对2,,...,n生成排列,
思路:
1.对0到n-1位置上的数字生成排列,具体做法 从1,,..,n中按序拿出数字i(i从1开始到n)与位置j(j从0开始到n-1)上的数字交换,再对位置j+1到n-1位置上的数字生成排列。
2.对j(j从1开始)到n-1位置上的数字生成排列,具体做法 从2,,..,n中按序拿出数字i(从2开始)与位置j上的数字交换,再对位置j+1到n-1位置上的数字生成排列。
3.......当j = n时,生成一个排列并打印
4. 回溯上一步,拿出数字i+1与j上的数字交换,并对j+1后面的序列生成排序
5. 直到i>n,结束
#include <iostream> using namespace std; void permutation(int* array, int iLength, int iCurStep) { if(iLength == iCurStep) //若固定位置指针指到最后一个数字打印数组 { for(int i=0;i<iLength;i++) { cout<<array[i]<<" "; } cout<<"\n"; return ; } else { for(int i = iCurStep ; i<iLength ; i++) //i为从固定指针位置到最后一个数字位置的扫描指针 { swap(array[iCurStep],array[i]); //固定从iCurStep起每个位置上的数字到iCurStep上 permutation(array,iLength,iCurStep+1); swap(array[i],array[iCurStep]); //复原array } } } int main(){ int array[] = {1,2,3,4}; permutation(array, 4, 0); }
标签:算法
原文地址:http://blog.csdn.net/xz_rabbit/article/details/41411619