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

    }
};
相关推荐
Code_LT1 天前
【算法】多榜单排序->综合排序问题
人工智能·算法
Tiny番茄1 天前
146. LRU缓存
数据结构·leetcode·缓存
仟濹1 天前
【力扣LeetCode】 1413_逐步求和得到正数的最小值
算法·leetcode·职场和发展
9毫米的幻想1 天前
【Linux系统】—— 进程切换&&进程优先级&&进程调度
linux·运维·服务器·c++·学习·算法
测试19981 天前
selenium三种等待方式详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
YoungHong19921 天前
面试经典150题[037]:矩阵置零(LeetCode 73)
leetcode·面试·矩阵
西阳未落1 天前
数据结构初阶——哈希表的实现(C++)
算法·哈希算法·散列表
未知陨落1 天前
LeetCode:46.二叉树展开为链表
算法·leetcode·链表
小欣加油1 天前
leetcode 206 反转链表
数据结构·c++·算法·leetcode·链表·职场和发展
野犬寒鸦1 天前
力扣hot100:环形链表II(哈希算法与快慢指针法思路讲解)
java·数据结构·算法·leetcode·链表·哈希算法