
B - 数据结构实验之图论二:图的深度遍历(DFS)
发布日期:2021-05-04 14:45:12
浏览次数:25
分类:原创文章
本文共 1134 字,大约阅读时间需要 3 分钟。
Description
请定一个无向图,顶点编号从0到n-1,用深度优先搜索(DFS),遍历并输出。遍历时,先遍历节点编号小的。
Input
输入第一行为整数n(0 < n < 100),表示数据的组数。 对于每组数据,第一行是两个整数k,m(0 < k < 100,0 < m < k*k),表示有m条边,k个顶点。 下面的m行,每行是空格隔开的两个整数u,v,表示一条连接u,v顶点的无向边。
Output
输出有n行,对应n组输出,每行为用空格隔开的k个整数,对应一组数据,表示DFS的遍历结果。
Sample
Input
14 40 10 20 32 3
Output
0 1 2 3
答案:
#include <bits/stdc++.h>#define ll long longconst int N = 1e5 + 10;using namespace std;int mp[111][111];bool vis[111];int n;int dp[111];int cnt=0;void DFS(int k){ vis[k]=1; dp[++cnt]=k; for(int i=0; i<n; i++) { if(!vis[i]&&mp[k][i]) { DFS(i); } }}int main(){ int t; cin>>t; while(t--) { int m; cin>>n>>m; memset(dp,0,sizeof(dp)); memset(mp,0,sizeof(mp)); memset(vis,0,sizeof(vis)); int i; for(i=1; i<=m; i++) { int x,y; cin>>x>>y; mp[x][y]=mp[y][x]=1; } cnt=0; DFS(0); for(i=1;i<=cnt;i++) { if(i==cnt) printf("%d\n",dp[i]); else printf("%d ",dp[i]); } } return 0;}