LeetCode 刷题【31. 下一个排列】

31. 下一个排列

自己做

解:排序实现

cpp 复制代码
class Solution {
public: 
    void nextPermutation(vector<int>& nums) {
        int nums_len = nums.size();

        if(nums_len == 1)          //只有一个元素不处理,直接返回
            return;

        int i = nums_len - 2;       //前一元素
        int j = nums_len - 1;       //后一元素

        //找到前一元素比后一元素小的元素
        while(i >= 0 && nums[i] >= nums[j]){
            j = i;
            i--;                    //前移
        }

        //这里要么发现了前一元素(i = xxx)比后一元素小,要么整个数组都是倒序的(i = -1)
        //倒序的情况
        if(i == -1)                                          //如果数组是倒序的
            return sort(nums.begin(), nums.end());         //升序排序
            
        //找到比i大的最小值(从j往后的位置)

        //将i往后的元素重新排为升序
        vector<int>::iterator it = nums.begin();
        for(int z = 0; z < i + 1; z++)          //找到i+1位置的指针
            it++;

        sort(it,nums.end());                    //排序i+1往后的元素(升序)

        for(int z = j; z < nums_len; z++)
            if(nums[z] > nums[i]){                      //找到了
                //交换元素
                int temp = nums[z];
                nums[z] = nums[i];
                nums[i] = temp;
                break;
            }
            
        //交换后重新排序
        sort(it,nums.end());                    //排序i+1往后的元素(升序)

    }
};
相关推荐
智者知已应修善业6 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
还不秃顶的计科生6 小时前
LeetCode 热题 100第二题:字母易位词分组python版本
linux·python·leetcode
LYFlied6 小时前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
多米Domi0117 小时前
0x3f 第19天 javase黑马81-87 ,三更1-23 hot100子串
python·算法·leetcode·散列表
坚持学习前端日记7 小时前
软件开发完整流程详解
学习·程序人生·职场和发展·创业创新
历程里程碑7 小时前
滑动窗口最大值:单调队列高效解法
数据结构·算法·leetcode
課代表7 小时前
从初等数学到高等数学
算法·微积分·函数·极限·导数·积分·方程
ullio7 小时前
arc206d - LIS ∩ LDS
算法
等等小何8 小时前
leetcode1593拆分字符串使唯一子字符串数目最大
算法
王老师青少年编程9 小时前
2025年12月GESP(C++二级): 环保能量球
c++·算法·gesp·csp·信奥赛·二级·环保能量球