n个数字的排列
和全排列类似,不过不是1开始,是指定的数字开始
Problem Detail - 【递归】n个数的全排列 - 追梦算法网
#include<iostream> #include<algorithm> using namespace std; const int N=15; int a[N],p[N]; bool st[N];//判重,不能填一样的数字 int n; void dfs(int u) { if(u>n) { for(int i=1;i<=n;i++)//p数组是填数的 cout<<p[i]<<" "; cout<<endl; return ; } for(int i=1;i<=n;i++) { if(!st[a[i]]) { p[u]=a[i]; st[a[i]]=true; dfs(u+1); st[a[i]]=false; } } } int main(){ cin>>n; for(int i=1;i<=n;i++) cin>>a[i]; sort(a+ 1,a+n+1); dfs(1); return 0; }
浙公网安备 33010602011771号