码迷,mamicode.com
首页 > 编程语言 > 详细

next_permutation(全排列算法)

时间:2019-08-06 14:13:04      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:原创   版权   first   next   固定   排列   on()   blog   log   

考虑三个字符所组成的序列{a,b,c}。

      这个序列有六个可能的排列组合:abc,acb,bac,bca,cab,cba。这些排列组合根据less-than操作符做字典顺序(lexicographical)的排序。也就是说,abc名列第一,因为每一个元素都小于其后的元素。acb是次一个排列组合,因为它是固定了a(序列内最小元素)之后所做的新组合。

      同样道理,那些固定b(序列中次小元素)而做的排列组合,在次序上将先于那些固定c而做的排列组合。以bac和bca为例,bac在bca之前,因为次序ac小于序列ca。面对bca,我们可以说其前一个排列组合是bac,而其后一个排列组合是cab。序列abc没有“前一个”排列组合,cba没有“后一个”排列组合。

     next_permutation()会取得[first,last)所标示之序列的下一个排列组合,如果没有下一个排列组合,便返回false;否则返回true。
---------------------
版权声明:本文为CSDN博主「小与米」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/c18219227162/article/details/50301513

next_permutation(全排列算法)

标签:原创   版权   first   next   固定   排列   on()   blog   log   

原文地址:https://www.cnblogs.com/ljy-endl/p/11308181.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!