博客
关于我
A - 数据结构实验之图论一:基于邻接矩阵的广度优先搜索遍历(BFS)
阅读量:265 次
发布时间:2019-03-01

本文共 1242 字,大约阅读时间需要 4 分钟。

Description

给定一个无向连通图,顶点编号从0到n-1,用广度优先搜索(BFS)遍历,输出从某个顶点出发的遍历序列。(同一个结点的同层邻接点,节点编号小的优先遍历)

Input

输入第一行为整数n(0< n <100),表示数据的组数。

对于每组数据,第一行是三个整数k,m,t(0<k<100,0<m<(k-1)*k/2,0< t<k),表示有m条边,k个顶点,t为遍历的起始顶点。
下面的m行,每行是空格隔开的两个整数u,v,表示一条连接u,v顶点的无向边。

Output

输出有n行,对应n组输出,每行为用空格隔开的k个整数,对应一组数据,表示BFS的遍历结果。

Sample

Input

16 7 00 30 41 41 52 32 43 5

Output

0 3 4 2 5 1

Hint

以邻接矩阵作为存储结构。

答案:

#include 
#include
#define ll long longconst int N = 1e5 + 10;using namespace std;int mp[222][222]; //邻接表int dp[222]; //记录遍历的点bool vis[222]; //标记int cnt;void BFS(int pos,int n) //pos为起点,n为长度{ queue
q; vis[pos]=1; dp[++cnt]=pos; q.push(pos); while(!q.empty()) { int v=q.front(); q.pop(); int i; for(i=0;i
>T; while(T--) { int k,m,t; cin>>k>>m>>t; memset(mp,0,sizeof(mp)); memset(vis,0,sizeof(vis)); int x,y; int i; while(m--) { cin>>x>>y; mp[x][y]=mp[y][x]=1; //建立邻接表 } cnt=0; BFS(t,k); for(i=1;i<=cnt;i++) { if(i==cnt) printf("%d\n",dp[i]); else printf("%d ",dp[i]); } } return 0;}

转载地址:http://vdia.baihongyu.com/

你可能感兴趣的文章
Mysql客户端中文乱码问题解决
查看>>
mysql客户端工具使用
查看>>
MySQL密码忘记,怎么办?
查看>>
mysql导入数据库出现:Incorrect string value: '\xE7\x82\xB9\xE9\x92\x9F' for column 'chinese' at row 1...
查看>>
mysql导入(ibd文件)
查看>>
Mysql工作笔记006---Mysql服务器磁盘爆满了_java.sql.SQLException: Error writing file ‘tmp/MYfXO41p‘
查看>>
mysql常用命令
查看>>
MySQL底层概述—2.InnoDB磁盘结构
查看>>
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>