首页 > 代码库 > 算法笔记03--归纳法之生成排列
算法笔记03--归纳法之生成排列
生成排列
生成排列即对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); }
算法笔记03--归纳法之生成排列
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。