IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 数据结构与算法——图 -> 正文阅读

[数据结构与算法]数据结构与算法——图

图的邻接矩阵存储及其深度遍历与广度遍历实现

原理讲解视频推荐:
DFS:懒猫老师的DFS介绍
BFS:懒猫老师的BFS介绍
以上视频结合动图加深理解,个人觉得非常推荐~
原理讲解文字版

#include<iostream>
#include<queue>
using namespace std;
#define maxsize 100 
//邻接矩阵方式实现图 
//是否访问过该顶点,故为一维的! 由于递归的不断变化,故要设置成全局变量 
int visited[maxsize] = {0};
template <class datatype>
class Graph{
	public:
		Graph(datatype a[], int n,int e);//有参构造函数 
		~Graph(){	};
		void DFS(int v);//从点v开始进行深度优先遍历 
		void BFS(int v);//从点v开始进行广度优先遍历	
		void GraphAdjlist(); 
	private:
		datatype vertex[maxsize];//存放点 
		int arc[maxsize][maxsize];//存放边数组
		int vertex_num, arc_num; 
	
};
template<class datatype>
Graph<datatype>::Graph(datatype a[],int n,int e)//构造函数不需要返回类 
{
	//类内私有成员共享
	vertex_num = n;
	arc_num = e;
	for(int i = 0;i<vertex_num;++i)
		vertex[i] = a[i];//顶点数组
	for(int i = 0;i<vertex_num;++i)
	{
		for(int j = 0;j<arc_num;++j)
		{
			arc[i][j] = 0;//初始化矩阵 
		} 
	}
	for(int k = 0; k < arc_num;++k)
	{
		int i,j;
		cout<<"请输入邻接矩阵的两个点"<<endl; 
		cin>>i>>j;
			arc[i][j] = 1;//无向图 
			arc[j][i] = 1;
		
	 } 
 } 
 
template<class datatype>
void Graph<datatype>::DFS(int v)
{
 
 	cout<<"当前端点为: "<<vertex[v]<<endl;
 	visited[v] = 1; 
 	for(int j = 0; j < vertex_num; ++j)
 	{
 		//如果这个端点j和v有连接且还没被访问 
 		if(arc[v][j] == 1 && visited[j] == 0)
 			DFS(j);
	}
	  
} 
template<class datatype>
void Graph<datatype>::BFS(int v)
{
	
	int visited[vertex_num]= {0};
	queue<int> Q;
	visited[v] = 1;
	Q.push(v); 
	while(!Q.empty())
		{
			v = Q.front();
			cout<<"当前端点为: "<<vertex[v]<<endl; 
			Q.pop();
			for(int k = 0;k< vertex_num;++k)
			{
				if(visited[k] == 0 && arc[v][k] == 1)
				{
					visited[k] = 1; 
					Q.push(k);
				}	
			}
			
		}	
}
int main()
{
	char array[] = {'a','b','c','d','e','f','g'}; 
	Graph<char> graph(array,7,10);
	cout<<"/***************DFS_result:"<<endl;
	graph.DFS(5);
	cout<<"/***************BFS_result:"<<endl;
	graph.BFS(5);
	return 0;
}

懒猫老师的案例,从V5出发进行遍历输入与输出

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-07-13 17:44:00  更:2021-07-13 17:45:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 11:46:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码