全排列问题

来源:互联网 发布:儿童冬季服装淘宝网 编辑:程序博客网 时间:2024/06/05 07:45
//全排列问题
#include<stdio.h>
int a[10],book[10],n;
void dfs(int step)
{
int i;
if(step==n+1)
{
for(i=1;i<=n;i++)
printf("%d",a[i]);
printf("\n");

return; 
}
for(i=1;i<=n;i++)
{
if(book[i]==0)
{
a[step]=i;
book[i]=1;
dfs(step+1);
book[i]=0; 
}
}
return ;
}
int main()
{
scanf("%d",&n);
dfs(1);
getchar();
return 0;

}


主要用到了dfs思想