博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++中全排列算法函数next_permutation的使用方法
阅读量:6068 次
发布时间:2019-06-20

本文共 508 字,大约阅读时间需要 1 分钟。

首先,先看对next_permutation函数的解释: http://www.cplusplus.com/reference/algorithm/next_permutation/?kw=next_permutation

 

从中可以看出,全排列的第一个序列为从小到大排好序的序列,最后一个序列为从大到小排好序的序列。

使用next_permutation函数的注意点:

(1)在使用此函数之前,必须先对原序列使用sort进行排序,不然则不能获得其全部的全排列。

(2)在使用这些排列数作除法运算时,一定要将保存这些排列数的数组定义为double类型,或者将除法转变为乘法。

    因为int类型作除法会丢掉结果的小数部分,导致产生错误的答案!

(3)如果需要使用的个数小于全排列中的元素总数时,要注意判重。 例如,对1,2,3,4进行全排列,但是只需要取前两个

 数使用,此时就需要判重,因为1,2,3,4和1,2,4,3中前两个数都是一样的。如果不判重的话就可能出错。

 

注意事项简记为: 升序、除法、全序列。

转载于:https://www.cnblogs.com/FengZeng666/p/10458638.html

你可能感兴趣的文章
开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
查看>>
开源磁盘加密软件VeraCrypt教程
查看>>
本地vs云:大数据厮杀的最终幸存者会是谁?
查看>>
阿里云公共镜像、自定义镜像、共享镜像和镜像市场的区别 ...
查看>>
shadowtunnel v1.7 发布:新增上级负载均衡支持独立密码
查看>>
IdleHandler,页面启动优化神器
查看>>
Java线程:什么是线程
查看>>
mysql5.7 创建一个超级管理员
查看>>
【框架整合】Maven-SpringMVC3.X+Spring3.X+MyBatis3-日志、JSON解析、表关联查询等均已配置好...
查看>>
要想成为高级Java程序员需要具备哪些知识呢?
查看>>
带着问题去学习--Nginx配置解析(一)
查看>>
onix-文件系统
查看>>
java.io.Serializable浅析
查看>>
我的友情链接
查看>>
多线程之线程池任务管理通用模板
查看>>
CSS3让长单词与URL地址自动换行——word-wrap属性
查看>>
CodeForces 580B Kefa and Company
查看>>
开发规范浅谈
查看>>
Spark Streaming揭秘 Day29 深入理解Spark2.x中的Structured Streaming
查看>>
鼠标增强软件StrokeIt使用方法
查看>>