您的位置:首页 > 其它

回溯法求n的全排列

2016-10-18 20:58 120 查看
代码如下:

#include <iostream>
#include <algorithm>
#include <stdio.h>
#include <cstring>
#include <cmath>
#include <map>
#include <bitset>
using namespace std;
typedef long long LL;
int x[105];
int n;
void Backtrack(int t)
{
if(t==n){
for(int i=1;i<=n;i++)
cout<<x[i]<<" ";
cout<<endl;
return ;
}
for(int i=t;i<=n;i++)
{
swap(x[i],x[t]);
Backtrack(t+1);
swap(x[i],x[t]);
}
}
int main()
{
for(int i=1;i<105;i++)
x[i]=i;
while(scanf("%d",&n)!=EOF)
{
cout<<n<<"的全排列如下:"<<endl;
Backtrack(1);
cout<<"finish!"<<endl;
}
return 0;
}


运行截图:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: