排列问题
对给出的n个数,求出其所有的排列。
思路:对于R={r1,r2,r3.......rn},其全排列可以这样去计算,
perm(R)=riperm(R-ri);(1<=i<=n)
即以ri为前缀不变,对剩下所有的元素进行排列。即分别以r1,r2,r3,....rn作为前缀不变,对剩下的所有元素进行全排列即为所得到的结果。同理对于perm(R-ri)的求解也是一个相同的过程,因此可以采用递归的思想去解决。
#include<iostream> using namespace std; void swap(int &a,int &b) { int temp=a; a=b; b=temp; } //函数Perm(int a[],int k,int m)是求将a的第1~k-1个元素不动、第k~m个元素进行全排列得到的全排列 void perm(int *a,int k,int m) { if(k==m) //如果前缀是最后一个位置,即只剩下一个元素了 { int i; for(i=1;i<m;i++) { printf("%d ",a[i]); } printf("%d\n",a[i]); } else { for(int i=k;i<=m;i++) { swap(a[k],a[i]); //交换前缀 perm(a,k+1,m); swap(a[k],a[i]); //产生完排列后,换回原来的位置 } } } int main(void) { int n; int *a; while(scanf("%d",&n)==1&&n>=1) { a=(int *)malloc((n+1)*sizeof(int)); for(int i=1;i<=n;i++) { scanf("%d",&a[i]); } perm(a,1,n); } return 0; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?