当前位置: 首页 > news >正文

图论---图的遍历

        在图论中,图的遍历一般有两种,分别为DFS(深度优先遍历)、BFS(广度优先遍历),以下是这两种遍历方式的模板:

DFS(深度优先搜索)

代码框架:

void dfs(参数) {if (终止条件) {存放结果;return;}
​for (选择:本节点所连接的其他节点) {处理节点;dfs(图,选择的节点); 回溯,撤销处理结果}
}
void main_function(参数){for(遍历所有节点){if(节点未遍历){dfs(该节点)}}
}

BFS(广度优先搜索)

代码框架:

int dir[4][2] = {0, 1, 1, 0, -1, 0, 0, -1}; // 表示四个方向
void bfs(vector<vector<char>>& grid, vector<vector<bool>>& visited, int x, int y) {int m = grid.size(),n = grid[0].size();queue<pair<int, int>> que; // 定义队列que.push({x, y}); // 起始节点加入队列visited[x][y] = true; // 只要加入队列,立刻标记为访问过的节点while(!que.empty()) { // 开始遍历队列里的元素auto cur = que.front(); // 从队列取元素que.pop(); int x = cur.first;int y = cur.second; // 当前节点坐标for (int i = 0; i < 4; i++) { // 开始想当前节点的四个方向左右上下去遍历int tx = x + dir[i][0];int ty = y + dir[i][1]; // 获取周边四个方向的坐标if (tx >= 0 && tx < m && ty >= 0 && ty < n && !visited[tx][ty]) { // 如果节点没被访问过que.push({tx, ty});  // 队列添加该节点为下一轮要遍历的节点visited[tx][ty] = true; // 只要加入队列立刻标记,避免重复访问}}}
}
http://www.lryc.cn/news/186001.html

相关文章:

  • AM@无穷小和无穷大
  • 玄子Share- IDEA 2023 SpringBoot 热部署
  • kafka集群工作机制
  • JVM上篇之虚拟机与java虚拟机介绍
  • 在公众号上怎么创建微信付费课程功能呢
  • HTML5使用html2canvas转化为图片,然后再转为base64.
  • 【C++设计模式之原型模式:创建型】分析及示例
  • TDengine OSS 与 qStudio 实现无缝协同,革新数据分析和管理方式
  • css的gap设置元素之间的间隔
  • Flask-[项目]-搭建短网址系统:flask实现短网址系统,短网址系统,构建短网址系统
  • 【从0开始配置前后端项目】——Docker环境配置
  • R语言 一种功能强大的数据分析、统计建模 可视化 免费、开源且跨平台 的编程语言
  • springmvc-JSR303进行服务端校验分组验证SpringMVC定义Restfull接口异常处理流程RestController异常处理
  • 证件照换底色详细教程
  • 【ringbuff share mem】
  • 【Zookeeper专题】Zookeeper经典应用场景实战(一)
  • 【数据库——MySQL】(15)存储过程、存储函数和事务处理习题及讲解
  • FFmpeg:打印音/视频信息(Meta信息)
  • 1.Linux入门基本指令
  • 2023腾讯云服务器优惠代金券领取、查询及使用说明
  • 大华智慧园区管理平台任意密码读取漏洞 复现
  • 【C++ 学习 ㉖】- 位图详解(哈希扩展)
  • 天启科技联创郭志强:趟遍教育行业信数化沟坎,创业智能赛道重塑行业生态
  • Cuckoo沙箱各Ubuntu版本安装及使用
  • 什么是mvvm模式,优点是什么
  • C/C++ 中的函数返回局部变量以及局部变量的地址?
  • springboot和vue:七、mybatis/mybatisplus多表查询+分页查询
  • 【Leetcode】 51. N 皇后
  • Java数据库连接:JDBC介绍与简单示例
  • 智慧茶园:茶厂茶园监管可视化视频管理系统解决方案