标签:leetcode reverse next_permutation
一、 题目
这道题给出一个数列,求大于这个数列的最小数列。
例如:
1,2,3 → 1,3,2
3,2,1 → 1,2,3
1,1,5 → 1,5,1
二、 分析
喜欢使用C++的童鞋或许会马上想到next_permutation()这个库函数,没错,其实这道题就是实现的它(严格说来只是初步实现),如果可以的话,如果直接输入这一行代码就可通过:
void nextPermutation(vector<int> &num) { next_permutation( num.begin(), num.end() ); }
但是,可不是说我们就这样结束了,当然不能,我们要自己实现它。观察数列会发现,如果数列是递减的话我们是找不出比他更大的数列的,所以我们要找到两个递增元素,即从右到左找到第一个左边小于右边的元素,然后我们再找出该元素右边比他大的最小的元素,交换两数,然后再将该数后面的数列reverse()即可。
分为四步:
1、 从右到左找到第一个左边小于右边的元素num[i];
2、 从右到左找到第一个大于num[i]的元素num[j]
3、 交换num[i]和num[j];
4、 将num[i]后的数列reverse()
代码如下:
class Solution { public: void nextPermutation(vector<int> &num) { int len = num.size()-1; int count = len-2; int i,j; for(i=len-1; i>=0; i--){ if(num[i+1]>num[i]){ for(j=len; j>i-1; j--){ if(num[j]>num[i]) break; } swap(num[i],num[j]); reverse(num.begin()+i+1,num.end()); return; } } reverse(num.begin(),num.end()); return; } void swap(int &a, int &b){ a = a + b; b = a - b; a = a - b; } };
标签:leetcode reverse next_permutation
原文地址:http://blog.csdn.net/zzucsliang/article/details/43100145