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往后的元素(升序)

    }
};
相关推荐
不想看见4041 分钟前
Merge k Sorted Lists 优先队列--力扣101算法题解笔记
笔记·算法·leetcode
_深海凉_3 分钟前
LeetCode热题100-合并区间
算法·leetcode·职场和发展
6Hzlia4 分钟前
【Hot 100 刷题计划】 LeetCode 79. 单词搜索 | C++ 标准方向数组 DFS 与回溯
c++·leetcode·深度优先
wuweijianlove6 分钟前
算法性能测试中的输入规模与边界影响的技术6
算法
MicroTech20259 分钟前
微算法科技(NASDAQ :MLGO)量子增强区块链联邦学习:基于量子拜占庭协议的技术革新
科技·算法·区块链
山河君15 分钟前
从后验到先验:语音信噪比估计与DD算法详解
算法·音视频·语音识别·信号处理
阿Y加油吧18 分钟前
栈的经典应用:字符串解码 & 每日温度 深度解析
数据结构·python·算法
小O的算法实验室20 分钟前
2025年EAAI,累积二项分布概率人工蜂群算法+机械工程设计全局优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
虎头金猫26 分钟前
GodoOS是一款轻量级云端办公系统,整合Word、Excel、PPT等常用工具,支持Docker 一键部署,随时随地远程办公
运维·服务器·网络·程序人生·docker·容器·职场和发展
千谦阙听35 分钟前
数据结构最终章:万字详解排序算法!(内部排序)
c语言·数据结构·学习·算法·排序算法