Next Permutation(Leetcode 31)

记住方法就可以,找到第一个nums[i] < nums[i+1] 的位置 i
然后从i+1往后扫,找到第一个小于nums[i]的位置 j,
最后swap(nums[i], nums[j-1]), 然后将 i 后面排序

重点是判断时一定都要加等于号。

class Solution {
public:
    void nextPermutation(vector& nums) {
        if(nums.size() <= 1) return;
        int i=nums.size()-1;
        while(i > 0 && nums[i] <= nums[i-1]) i--;
        if(i == 0){
            reverse(nums.begin(), nums.end());
            return;
        }
        i--;
        int j = i+1;
        for(; j

你可能感兴趣的:(Next Permutation(Leetcode 31))