该题的思路是从后向前扫描数组,找到第一对位置 i,j (i < j) 使得 i 位置的值小于 j 位置的值,交换 i 位置和 j 位置的元素值,然后对 i 位置之后的元素进行排序即可。代码如下:
vector<int> nextPermutation(vector<int> &nums) { // write your code here int size = nums.size(); //标记数组是否为递减数组 bool flag = false; //找出从后向前第一个不递增的元素 int i = size - 1; for(; i > 0; i--){ if(nums[i - 1] < nums[i]){ flag = true; break; } } //若数组为递减数组,则下一个全排列直接反转数组即可 if(flag == false){ sort(nums.begin(), nums.end()); return nums; } //找到第一个比反转元素大的元素 int k = size - 1; while(nums[k] <= nums[i - 1]) k--; //交换元素 int tmp = nums[i - 1]; nums[i - 1] = nums[k]; nums[k] = tmp; //排序剩余元素 sort(nums.begin() + i, nums.end()); return nums; }
版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/ny_mg/article/details/48102767