# leetcode 31. Next Permutation (in-place 生成下一个全排列)

Posted by 111qqz on Thursday, April 13, 2017

## TOC

Implement next permutation, which rearranges numbers into the lexicographically next greater permutation of numbers.

If such arrangement is not possible, it must rearrange it as the lowest possible order (ie, sorted in ascending order).

The replacement must be in-place, do not allocate extra memory.

Here are some examples. Inputs are in the left-hand column and its corresponding outputs are in the right-hand column.
`1,2,3``1,3,2`
`3,2,1``1,2,3`
`1,1,5``1,5,1`

``````  1. Find the largest index _k_ such that _a_[_k_] < _a_[_k_ + 1]. If no such index exists, the permutation is the last permutation.
2. Find the largest index _l_ greater than k such that _a_[_k_] < _a_[_l_].
3. Swap the value of _a_[_k_] with that of _a_[_l_].
4. Reverse the sequence from _a_[_k_ + 1] up to and including the final element _a_[_n_].
``````
``````/* ***********************************************
Author :111qqz
Created Time :2017年04月13日 星期四 14时39分33秒
File Name :31.cpp
************************************************ */
class Solution {

public:

void nextPermutation(vector<int>& nums) {

int n = nums.size();
if (n==0) return;
int k = -1;
for (int i = n-2 ;  i>= 0 ; i--)
if (nums[i]<nums[i+1])
{
k = i;
break;
}
if (k==-1)
{
reverse(nums.begin(),nums.end());
return;
}
int l = -1;
for ( int i = n-1 ; i > k ; i--)
{
if (nums[k]<nums[i])
{
l = i;
break;
}
}
swap(nums[l],nums[k]);
reverse(nums.begin()+k+1,nums.end());

}

};
``````

「真诚赞赏，手留余香」