前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >31. Next Permutation

31. Next Permutation

作者头像
平凡的学生族
发布2019-05-25 10:05:49
4800
发布2019-05-25 10:05:49
举报
文章被收录于专栏:后端技术后端技术
  1. Next Permutation https://yq.aliyun.com/articles/863 思路 假设有一个数: abcd...hi...wxyz 从i到z递减,且h小于i。 我们的任务是找到一个排列比它大,且尽可能小。 那么如果要找一个比它大的数,这个数的第一位不同必须在h上。下面用反证法证明:
  2. 如果该位在h以前,也就是abc...一直到h之前,那么这个数一定比 在h位上不同的数要大。
  3. 如果该位在h之后,也就是i...wxyz,那就说明i位之前的数都是一样的,没有交换过。而i...wxzy是递减的,在局部上本来就是数最大的排列,任何交换都无法使它更大。所以也不可能在h之后。

所以该位在h上。那么h要与谁交换呢?这个数肯定要比h大,但又要尽可能小。所以就在h右侧寻找比它大又尽可能小的数。将他们交换。然后剩下的数就从左到右,从小到大排序,就可以得到结果了。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.09.29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

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