邻接矩阵遍历(无向图,邻接矩阵,DFS,BFS)

2024-05-06 03:08

本文主要是介绍邻接矩阵遍历(无向图,邻接矩阵,DFS,BFS),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、题目:


 Problem Description

有多组数据,每组数据第一行有两个整数n、m,(0<n,m<100),n表示是有n个点(1~n)形成的图,接下来有m行数据,每一行有两个整数(表示点的序号),说明这两点之间有一条边。

 Input

分别输出从标号为1点开始深度和广度优先搜索的序列,每个数之后有一个空格。
每组数组分别占一行。

 Output

按存储顺序的先后,输出各连通分量中的顶点,每组输出占若干行,每行最后均有一空格,具体格式见样例。

 Sample Input

8 9
1 2
1 3
2 4
2 5
3 6
3 7
4 5
4 8
6 7

 Sample Output

1 2 4 5 8 3 6 7
1 2 3 4 5 6 7 8

 Author

janson


2、参考代码:


#include <iostream>
#include <string.h>
using namespace std;class MGraph{
private:int vertexNum,arcNum;int edge[111][111];int vertex[111];
public:int vis[111];MGraph(int* a,int n,int m);~MGraph(){}void DFS(int v);void BFS(int v);
};MGraph::MGraph(int* a,int n,int m){vertexNum=n;arcNum=m;int i,j;for(i=1;i<=n;i++)vertex[i]=a[i];memset(edge,0,sizeof(edge));while(m--){cin>>i>>j;edge[i][j]=edge[j][i]=1;}
}void MGraph::DFS(int v){cout<<vertex[v]<<" ";vis[v]=1;for(int j=0;j<=vertexNum;j++){if(edge[v][j]==1 && !vis[j])DFS(j);}
}void MGraph::BFS(int v){int front,rear;front=rear=-1;vis[v]=1;cout<<vertex[v]<<" ";int Q[111];Q[++rear]=v;while(front!=rear){v=Q[++front];for(int j=0;j<=vertexNum;j++){if(edge[v][j]==1 && !vis[j]){cout<<vertex[j]<<" ";vis[j]=1;Q[++rear]=j;}}}
}int main()
{int n,m,i,a[111];while(cin>>n>>m){for(i=1;i<=n;i++)a[i]=i;MGraph w(a,n,m);memset(w.vis,0,sizeof(w.vis));   ///记得每次开始搜索前都要清空标记w.DFS(1);cout<<endl;memset(w.vis,0,sizeof(w.vis));   ///记得每次开始搜索前都要清空标记w.BFS(1);cout<<endl;}return 0;
}



这篇关于邻接矩阵遍历(无向图,邻接矩阵,DFS,BFS)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/963317

相关文章

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

hdu1254(嵌套bfs,两次bfs)

/*第一次做这种题感觉很有压力,思路还是有点混乱,总是wa,改了好多次才ac的思路:把箱子的移动当做第一层bfs,队列节点要用到当前箱子坐标(x,y),走的次数step,当前人的weizhi(man_x,man_y),要判断人能否将箱子推到某点时要嵌套第二层bfs(人的移动);代码如下:

hdu 2489 (dfs枚举 + prim)

题意: 对于一棵顶点和边都有权值的树,使用下面的等式来计算Ratio 给定一个n 个顶点的完全图及它所有顶点和边的权值,找到一个该图含有m 个顶点的子图,并且让这个子图的Ratio 值在所有m 个顶点的树中最小。 解析: 因为数据量不大,先用dfs枚举搭配出m个子节点,算出点和,然后套个prim算出边和,每次比较大小即可。 dfs没有写好,A的老泪纵横。 错在把index在d

poj 3050 dfs + set的妙用

题意: 给一个5x5的矩阵,求由多少个由连续6个元素组成的不一样的字符的个数。 解析: dfs + set去重搞定。 代码: #include <iostream>#include <cstdio>#include <set>#include <cstdlib>#include <algorithm>#include <cstring>#include <cm

poj 2195 bfs+有流量限制的最小费用流

题意: 给一张n * m(100 * 100)的图,图中” . " 代表空地, “ M ” 代表人, “ H ” 代表家。 现在,要你安排每个人从他所在的地方移动到家里,每移动一格的消耗是1,求最小的消耗。 人可以移动到家的那一格但是不进去。 解析: 先用bfs搞出每个M与每个H的距离。 然后就是网络流的建图过程了,先抽象出源点s和汇点t。 令源点与每个人相连,容量为1,费用为

poj 2914 无向图的最小割

题意: 求无向图的最小割。 解析: 点击打开链接 代码: #pragma comment(linker, "/STACK:1677721600")#include <map>#include <set>#include <cmath>#include <queue>#include <stack>#include <vector>#include <cstd

POJ 3057 最大二分匹配+bfs + 二分

SampleInput35 5XXDXXX...XD...XX...DXXXXX5 12XXXXXXXXXXXXX..........DX.XXXXXXXXXXX..........XXXXXXXXXXXXX5 5XDXXXX.X.DXX.XXD.X.XXXXDXSampleOutput321impossible

ural 1149. Sinus Dances dfs

1149. Sinus Dances Time limit: 1.0 second Memory limit: 64 MB Let  An = sin(1–sin(2+sin(3–sin(4+…sin( n))…) Let  Sn = (…( A 1+ n) A 2+ n–1) A 3+…+2) An+1 For given  N print  SN Input One

hdu 6198 dfs枚举找规律+矩阵乘法

number number number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description We define a sequence  F : ⋅   F0=0,F1=1 ; ⋅   Fn=Fn

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr