DFS生成n个数的排列数
虽然在听完番茄的讲解之后自己把代码敲了出来,也能成功运行出正确的结果,但是感觉事实上我还是没有完全懂透彻搜索,即使我觉得我能够把这个题的搜索过程完全讲出来,但是也仅仅是这道题而已,完全理解搜索算法的思想感觉还有很长的路要走
【代码】
#include <cstdio>
#include <iostream>
#include <cstring>
#define NMAX 1000
using namespace std;
int a[NMAX];
int vis[NMAX];
void print(int n){ ///输出在数组a中已经填好的排列数
for(int i = 1; i <= n; i++){
printf("%d ", a[i]);
}
printf("\n");
}
void dfs(int depth, int n){ ///表示总共有n个数,正在搜索第depth个数
if(depth == n + 1){ ///已经填好n个数了
print(n); ///将填好的n个数输出
return;
}
for(int i = 1; i <= n; i++){///枚举所有可以用的数
if(!vis[i]){ ///当前这个数还没被用过
a[depth] = i; ///将当前数存在a数组中的第depth个位置
vis[i] = 1; ///标记该数已经用过
dfs(depth + 1, n); ///搜索下一层
vis[i] = 0; ///回溯,将该数的标记标为尚未用过
}
}
}
int main(){
int n;
scanf("%d", &n);
dfs(1, n); ///总共有n个数,正在搜第一个数
return 0;
}
当输入n=5时的输出:
5
1 2 3 4 5
1 2 3 5 4
1 2 4 3 5
1 2 4 5 3
1 2 5 3 4
1 2 5 4 3
1 3 2 4 5
1 3 2 5 4
1 3 4 2 5
1 3 4 5 2
1 3 5 2 4
1 3 5 4 2
1 4 2 3 5
1 4 2 5 3
1 4 3 2 5
1 4 3 5 2
1 4 5 2 3
1 4 5 3 2
1 5 2 3 4
1 5 2 4 3
1 5 3 2 4
1 5 3 4 2
1 5 4 2 3
1 5 4 3 2
2 1 3 4 5
2 1 3 5 4
2 1 4 3 5
2 1 4 5 3
2 1 5 3 4
2 1 5 4 3
2 3 1 4 5
2 3 1 5 4
2 3 4 1 5
2 3 4 5 1
2 3 5 1 4
2 3 5 4 1
2 4 1 3 5
2 4 1 5 3
2 4 3 1 5
2 4 3 5 1
2 4 5 1 3
2 4 5 3 1
2 5 1 3 4
2 5 1 4 3
2 5 3 1 4
2 5 3 4 1
2 5 4 1 3
2 5 4 3 1
3 1 2 4 5
3 1 2 5 4
3 1 4 2 5
3 1 4 5 2
3 1 5 2 4
3 1 5 4 2
3 2 1 4 5
3 2 1 5 4
3 2 4 1 5
3 2 4 5 1
3 2 5 1 4
3 2 5 4 1
3 4 1 2 5
3 4 1 5 2
3 4 2 1 5
3 4 2 5 1
3 4 5 1 2
3 4 5 2 1
3 5 1 2 4
3 5 1 4 2
3 5 2 1 4
3 5 2 4 1
3 5 4 1 2
3 5 4 2 1
4 1 2 3 5
4 1 2 5 3
4 1 3 2 5
4 1 3 5 2
4 1 5 2 3
4 1 5 3 2
4 2 1 3 5
4 2 1 5 3
4 2 3 1 5
4 2 3 5 1
4 2 5 1 3
4 2 5 3 1
4 3 1 2 5
4 3 1 5 2
4 3 2 1 5
4 3 2 5 1
4 3 5 1 2
4 3 5 2 1
4 5 1 2 3
4 5 1 3 2
4 5 2 1 3
4 5 2 3 1
4 5 3 1 2
4 5 3 2 1
5 1 2 3 4
5 1 2 4 3
5 1 3 2 4
5 1 3 4 2
5 1 4 2 3
5 1 4 3 2
5 2 1 3 4
5 2 1 4 3
5 2 3 1 4
5 2 3 4 1
5 2 4 1 3
5 2 4 3 1
5 3 1 2 4
5 3 1 4 2
5 3 2 1 4
5 3 2 4 1
5 3 4 1 2
5 3 4 2 1
5 4 1 2 3
5 4 1 3 2
5 4 2 1 3
5 4 2 3 1
5 4 3 1 2
5 4 3 2 1