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;}
上一篇:C - 数据结构实验之图论三:判断可达性(DFS)
下一篇:A - 数据结构实验之图论一:基于邻接矩阵的广度优先搜索遍历(BFS)

发表评论

最新留言

网站不错 人气很旺了 加油
[***.192.178.218]2025年03月14日 18时38分44秒