图的深度遍历
图的深度遍历
Time Limit: 1000MS Memory limit: 65536K
题目描述
请定一个无向图,顶点编号从0到n-1,用深度优先搜索(DFS),遍历并输出。遍历时,先遍历节点编号小的。
输入
输入第一行为整数n(0 < n < 100),表示数据的组数。 对于每组数据,第一行是两个整数k,m(0 < k < 100,0 < m < k*k),表示有m条边,k个顶点。 下面的m行,每行是空格隔开的两个整数u,v,表示一条连接u,v顶点的无向边。
输出
输出有n行,对应n组输出,每行为用空格隔开的k个整数,对应一组数据,表示DFS的遍历结果。
示例输入
1 4 4 0 1 0 2 0 3 2 3
示例输出
0 1 2 3
#include <stdio.h> #include <stdlib.h> #include <string.h> int map[101][101]; int mv[101];//mv为标记数组 void dfs(int a, int n) { int i; mv[a] = 1; for(i=0; i<n; i++) { if(mv[i] == 0 && map[a][i] != 0) { printf(" %d", i); dfs(i, n); } } } int main() { int T, n, m, u, v;//n,m分别表示点的个数,边的条数,u,v分别 // 表示每条边的始点和终点。 scanf("%d", &T); while(T--) { memset(map, 0, sizeof(map));//数组清零,下同。 memset(mv, 0, sizeof(mv)); scanf("%d %d", &n, &m); while(m--) { scanf("%d %d", &u, &v); map[u][v]=1; map[v][u]=1; } printf("%d", 0); dfs(0, n); printf("\n"); } return 0; }
每天训练发现我比别人做的好慢,但是理解的更深刻,如果一开始学一个新知识点就搜模板,那么这样的人是走不远的,毕业之后带走的只有思维,什么荣誉,奖杯都已经不重要了。