首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 31. Next Permutation

LeetCode 31. Next Permutation

作者头像
ShenduCC
发布2019-07-18 15:35:15
2790
发布2019-07-18 15:35:15
举报
文章被收录于专栏:算法修养算法修养

题目

c++

class Solution {
public:
    void nextPermutation(vector<int>& nums) {

        int tag=0;
        int z=-1;
        for(int i=nums.size()-1;i>=0;i--)
        {
            if(i!=0&&nums[i]>nums[i-1])
            {
                z=i-1;
                break;
            }  
        }
        
        if(z==-1){
            sort(nums.begin(),nums.end());
            return;
        }
        
        for(int i=nums.size()-1;i>=z;i--)
        {
           int pos=-1;
           for(int j=i-1;j>=z;j--)
           {
               if(nums[i]>nums[j])
               {
                   pos=j;
                   break;
               }
           }
            if(pos!=-1)
            {
                swap(nums[i],nums[pos]);
                
                sort(nums.begin()+pos+1,nums.end());
                break;
            }
           
        }
        
        
    }
};
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-07-17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档