C++全排列中递归交换法怎么用
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,今天小编给大家分享一下C++全排列中递归交换法怎么用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起
千家信息网最后更新 2025年01月22日C++全排列中递归交换法怎么用
今天小编给大家分享一下C++全排列中递归交换法怎么用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
题目描述
输出自然数1到n所有不重复的排列,即n的全排列,要求所产生的任一数字序列中不允许出现重复的数字。
输入格式
一个整数n。
输出格式
由1~n组成的所有不重复的数字序列,每行一个序列。
每个数字保留 5个场宽。
输入样例
3
输出样例
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1
全排列问题--递归交换法
其实跟暴力枚举思路差不多,每次递归枚举第x个数字是几,之后a[x]可以选择不动,也可以选择与后面任意一个数交换位置,就是从后面选一个数放到x的位置上。
简而言之,就是每到一位就从后面选一个尚未被使用过的数字与该位数字交换,这里有些难理解,您可以自己按照程序推一下样例。
这样我们就可以打印所有的全排列了,但这样不是按顺序打印,所以这里需要每次对a[x] ~ a[n]进行排序。
举个例子,如对1、2、3进行全排列。当我们交换1和3后,序列变为3、2、1,如果说这里不排序,直接2、1都保持不动,就输出3、2、1了,可是我们先要的应该是3、1、2,所以要进行排序。
最后,算一下时间复杂度,我们发现需要从1到n一位一位的看,之后每位还要枚举x ~ n,所以总时间复杂度为O(n!)。
代码
# include# include # include # include using namespace std;const int N_MAX = 10;int n;int a[N_MAX + 10];void permutation(int x){ if (x == n) { for (int i = 1; i <= n; i++) printf("%5d", a[i]); printf("\n"); return; } for (int i = x; i <= n; i++) { sort(a + x, a + n + 1); swap(a[x], a[i]); permutation(x + 1); swap(a[x], a[i]); }}int main(){ scanf("%d", &n); for (int i = 1; i <= n; i++) a[i] = i; permutation(1); return 0;}
以上就是"C++全排列中递归交换法怎么用"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
数字
递归
序列
知识
篇文章
输出
排序
C++
复杂
个数
位置
内容
复杂度
就是
时间
格式
输入
选择
不同
很大
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
大禾互联网科技有限公司
怎么让数据库时间显示到分
西安应用软件开发外包
银保信网络安全及Ups
数据库中主键 索引和外键
嘉兴最新招工信息软件开发6
oppo手机官网云服务器
vb上数据库
网络安全发培训
阿里云北京和杭州服务器云空间
建立学籍数据库
互联网数据库同步训练
数据库查询班级名称
数据库2008连接服务器
新闻系统软件开发费用
房管局数据库app
服务器添加打印机
西安电费缴费软件开发团队
绵阳靠谱软件开发公司
第一个我的世界开了服务器的是谁
如何将数据库数据显示到网页
网络安全审计员岗位职责
虚拟服务器安全防护
数据库快递单
广州软件开发驻场代理公司
如何管理服务器里面的进程
组播业务软件开发怎么样
绝地求生2未来之役有几个服务器
不能保证网络安全英文
信阳工业学校网络安全活动