生成排列
生成排列即对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);
}