
【leetcode】31. 下一个排列(next-permutation)(模拟)[中等]
发布日期:2021-05-13 21:40:26
浏览次数:19
分类:精选文章
本文共 989 字,大约阅读时间需要 3 分钟。
链接
耗时
解题:4 h 45 min
题解:13 min题意
实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。
如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。
必须原地修改,只允许使用额外常数空间。
思路
实现 C++ 的 next_permutation() 。
从后向前找到第一个非逆序的数字 nums[i],然后在 [i+1,n-1] 里面找大于 nums[i] 的最小的数字 nums[pos],交换 nums[i] 和 nums[pos],然后将 [i+1,n-1] 区间的数字从小到大排序。
如果不存在非逆序的数字,说明不存在下一个更大的排列,直接翻转 nums[] 。
时间复杂度: O ( n l o g n ) O(nlogn) O(nlogn)
AC代码
class Solution { public: void nextPermutation(vector & nums) { int n = nums.size(); if(n <= 1) return ; for(int i = n-2; i >= 0; --i) { if(nums[i] >= nums[i+1]) continue; int tmp = INT_MAX, pos = i; for(int j = i+1; j < n; ++j) { if(nums[j] > nums[i] && nums[j] < tmp) { tmp = nums[j]; pos = j; } } swap(nums[pos], nums[i]); sort(nums.begin()+i+1, nums.end()); return ; } reverse(nums.begin(), nums.end()); }};
发表评论
最新留言
逛到本站,mark一下
[***.202.152.39]2025年04月21日 17时31分33秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
链上钱包的博彩雷区
2021-05-14
GRUB2
2021-05-14
微信JS-SDK DEMO页面和示例代码
2021-05-14
Chrome查找发请求的js之黑箱调试
2021-05-14
GridView的另外一种分页方式,可提高加载速度
2021-05-14
GridView自定义删除操作
2021-05-14
一张图搞定RPC框架核心原理
2021-05-14
Scala中的包
2021-05-14
他来了他来了,他带着云栖大会的免费门票走来了
2021-05-14
获取linux 主机cpu类型
2021-05-14
限流的算法有哪些?
2021-05-14
Android Studio updating indices 一直刷新和闪烁
2021-05-14
个人购买服务器问题?
2021-05-14
pwntools编写技巧
2021-05-14
How2Heap笔记(三)
2021-05-14
go--microSocket服务端 php客户端
2021-05-14
小程序提交新数据后如何返回上一页并刷新数据?
2021-05-14
qt c++实现的ai贪吃蛇吃满屏幕,超详细!(二)ai的具体实现
2021-05-14
linux 查看log日志相关命令
2021-05-14