数据结构-邻接矩阵的创建与遍历

上篇文章已经介绍了邻接矩阵的具体作用与如果利用邻接矩阵寻找相邻顶点,这次介绍重点为邻接矩阵的创建与两种遍历方式

邻接矩阵的创建

其结构体需要能记录顶点、顶点数、边数及邻接矩阵,即

#define max 100
typedef struct {
	int vex[max];//顶点(假设顶点为数字,如果为字符型则需要在创建邻接矩阵时进一步对应转换)
	int arc[max][max];//邻接矩阵
	int numN,numE;//顶点数与边数
}Mgraph;

创建方式则为读入边数、顶点数即各边的两个顶点和权值

void creat(Mgraph* G){
	cin>>G->numN>>G->numE;//读入顶点数与边数
	for (int i=0;i<G->numN;i++) cin>>G->vex[i];//记录顶点
	for (int i=0;i<G->numN;i++){
		for (int j=0;j<G->numN;j++){
			G->arc[i][j]=0;//邻接矩阵初始化
		}
	}
	while(G->numE--){
		int n1,n2,w;
		cin>>n1>>n2>>w;//读入相接的顶点及权值
		G->arc[n1][n2]=w;
		G->arc[n2][n1]=w;//无向图,矩阵对称
	}
}

图的遍历

DFS(深度优先遍历)

DFS就是从一个顶点出发,向未被访问过的相邻节点不断深入访问,直到所有与初始顶点相连通的节点都被访问过,再回溯到前一个节点,继续尝试另一条路径。通常用栈或递归来实现。

递归代码实现如下

#define max 100
bool book[max];
void dfs(Mgraph G,int i){
	...//终止条件
	book[i]=false;//标记这个顶点已经被访问过
	for (int j=0;j<G.numN;j++){
		if (G.arc[i][j]!=0&&book[j])//如果顶点i与顶点j之间连通且未访问过j
		dfs(G,j);//继续进行深搜
	}
}
int main(){
	Mgraph* G=new Mgraph;
	creat(G);
	for (int i=0;i<G->numN;i++){
		book[i]=true;//初始化标记数组
	}
	for (int i=0;i<G->numN;i++){
		if(book[i]) dfs(G,i);//对未被访问的顶点开始进行深搜
	}
	return 0;
}
BFS(广度优先遍历)

BFS具体操作为,从某个起点开始,先访问所有与它相邻的节点,然后再访问与这些节点相邻但还未被访问的节点,以此类推,直到遍历完整张图。bfs通常用队列来实现。

队列代码如下

(同样需要设置标记数组)

void bfs(Mgraph G){
	deque<int> q;
	for (int i=0;i<G.numN;i++){
		if (book[i]){
			book[i]=false;//标记此顶点已遍历
			q.push_back(i);
			while(!q.empty()){//当队列不为空时
			int temp=q.front();//记录队首元素
				q.pop_front();//队首出队
				for (int j=0;j<G.numN;j++){
					if (G.arc[temp][j]!=0&&book[j]){//将与原队首相邻的入队
						book[j]=false;//标记
						q.push_back(j);
					}
				}
			}
		}
	}
}
相关推荐
武子康5 分钟前
大数据-212 数据挖掘 机器学习理论 - 无监督学习算法 KMeans 基本原理 簇内误差平方和
大数据·人工智能·学习·算法·机器学习·数据挖掘
passer__jw76734 分钟前
【LeetCode】【算法】283. 移动零
数据结构·算法·leetcode
Ocean☾40 分钟前
前端基础-html-注册界面
前端·算法·html
顶呱呱程序1 小时前
2-143 基于matlab-GUI的脉冲响应不变法实现音频滤波功能
算法·matlab·音视频·matlab-gui·音频滤波·脉冲响应不变法
爱吃生蚝的于勒1 小时前
深入学习指针(5)!!!!!!!!!!!!!!!
c语言·开发语言·数据结构·学习·计算机网络·算法
羊小猪~~1 小时前
数据结构C语言描述2(图文结合)--有头单链表,无头单链表(两种方法),链表反转、有序链表构建、排序等操作,考研可看
c语言·数据结构·c++·考研·算法·链表·visual studio
王哈哈^_^2 小时前
【数据集】【YOLO】【VOC】目标检测数据集,查找数据集,yolo目标检测算法详细实战训练步骤!
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·pyqt
星沁城2 小时前
240. 搜索二维矩阵 II
java·线性代数·算法·leetcode·矩阵
脉牛杂德2 小时前
多项式加法——C语言
数据结构·c++·算法
legend_jz2 小时前
STL--哈希
c++·算法·哈希算法