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

    }
};
相关推荐
PyHaVolask29 分钟前
数据结构与算法分析
数据结构·算法·图论
小王C语言29 分钟前
封装红黑树实现mymap和myset
linux·服务器·算法
大佬,救命!!!1 小时前
算法实现迭代2_堆排序
数据结构·python·算法·学习笔记·堆排序
Dream it possible!1 小时前
LeetCode 面试经典 150_栈_简化路径(53_71_C++_中等)(栈+stringstream)
c++·leetcode·面试·
程序员阿鹏1 小时前
49.字母异位词分组
java·开发语言·leetcode
天桥下的卖艺者1 小时前
R语言手搓一个计算生存分析C指数(C-index)的函数算法
c语言·算法·r语言
Espresso Macchiato1 小时前
Leetcode 3715. Sum of Perfect Square Ancestors
算法·leetcode·职场和发展·leetcode hard·树的遍历·leetcode 3715·leetcode周赛471
草莓熊Lotso2 小时前
《C++ Stack 与 Queue 完全使用指南:基础操作 + 经典场景 + 实战习题》
开发语言·c++·算法
敲上瘾2 小时前
单序列和双序列问题——动态规划
c++·算法·动态规划
太过平凡的小蚂蚁2 小时前
策略模式:让算法选择像点菜一样简单
算法·策略模式