【寸铁的刷题笔记】图论、bfs、dfs
【寸铁的刷题笔记】图论、bfs、dfs
大家好 我是寸铁👊
金三银四,图论基础
结合bfs
、dfs
是必考的知识点✨
快跟着寸铁刷起来!面试顺利上岸👋
喜欢的小伙伴可以点点关注 💝
🌞详见如下专栏🌞
🍀🍀🍀寸铁的刷题笔记🍀🍀🍀
200. 岛屿数量
考点
递归、dfs
思路
思路:遍历二维数组,遇到陆地则计数器加
1
然后,向该陆地上
、下
、左
、右
四个方向进行搜索。
遇到边界则停止
搜索,如果搜索到的网格为陆地
,则说明该网格和遍历到的陆地连通
。
同时,把该搜索到的陆地'1'
,置为海洋'0'
由于之前遍历二维数组时遇到陆地时计数器加1,由于连通,算作1
个岛屿。
这样就避免下次遍历二维数组时重复遍历
陆地,导致岛屿数量多算
了。
代码
class Solution {/*思路:遍历二维数组,遇到陆地则计数器加1然后,向该陆地上、下、左、右四个方向进行搜索。遇到边界则停止搜索,如果搜索到的网格为陆地,则该网格和遍历到的陆地连通。同时,把该搜索到的陆地'1',置为海洋'0'由于之前遍历二维数组时遇到陆地时计数器加1,由于连通,算作1个岛屿。这样就避免下次遍历二维数组时,重复遍历陆地,导致岛屿数量多算了。*/public int numIslands(char[][] grid) {int count = 0;//统计陆地的数量for(int i = 0; i < grid.length; i++){ //数组的行数for(int j = 0; j < grid[0].length; j++){//数组的列数if(grid[i][j] == '1'){//如果说遍历到的节点是陆地'1'dfs(grid , i , j);//则调用递归函数将该陆地周围的陆地进行置0操作count++;//陆地数量++ } }}return count;//返回陆地的数量}public void dfs(char [][]grid , int i , int j){//边界条件,遇到边界则搜索停下来。if(i < 0 || j < 0 || i >= grid.length || j >= grid[0].length || grid[i][j] == '0')return;//将陆地周围联通的陆地进行置0 , 避免重复遍历,统计陆地的数量不正确。grid[i][j] = '0';//向上、下、左、右四个方向进行遍历,把能走通的陆地进行置0,避免重复遍历。//上dfs(grid , i -1 , j);//下dfs(grid , i + 1 , j);//左dfs(grid , i , j - 1);//右dfs(grid , i , j + 1);}
}
130. 被围绕的区域
考点
递归、dfs
思路
题目描述
这道题是让我们寻找所有被X
围绕的区域,并将这块区域中的所有的'O
用X
进行填充。
转换问题
那么怎么样去寻找所有被X
围绕的区域呢?
直接做肯定不好做,不妨反过来思考,什么样的才是不被X
围绕的区域呢?
观察题目图形,我们发现如果
O
位于棋盘边界的位置,则说明O
不被X
所围绕,与外界连通。
那么问题就转换为去搜索从边界的O
开始连通的O
区域,这一部分连通的区域必定是不满足条件的,也就是不用替换为X
的。
所以,我们从边界的位置出发,去搜索从边界的O
开始连通的O
区域,并把搜索过的O
标记为*
,避免后面被重复遍历。
如下图绿色
为棋盘的边界部分
复原操作
最后,对棋盘的字符进行复原操作,把标记的*
复原为X
。
剩下的O
则为被包围的区域,进行替换为X
即可。
代码
class Solution {/*思路:这道题是让我们寻找所有被'X'围绕的区域,并将这块区域中的所有'O'用'X'进行填充。那么,怎么样去寻找所有被'X'围绕的区域呢?直接做肯定不好做,不妨反过来思考,什么样的才是不被'X'围绕的区域呢?观察图形,我们发现如果O位于棋盘边界的位置,则说明'O'不被'X'所围绕。那么问题就转换为去搜索从边界的'O'开始连通的'O'区域,这一部分连通的区域必定是不满足条件的,也就是不用替换为'X'的。所以,我们从边界的位置出发,去搜索从边界的'O'开始连通的'O'区域,并把搜索过的'O'标记为'*',避免后面被重复遍历。最后,对棋盘的字符进行复原操作,把标记的'*'复原为'X'。剩下的'O'则为被包围的区域,进行替换为'X'即可。*/int m;//棋盘的行数int n;//棋盘的列数public void solve(char[][] board) {m = board.length;//行的长度n = board[0].length;//列的长度for(int i = 0; i < m; i++){dfs(board , i , 0);//每一行的第一个位置dfs(board , i , n - 1);//每一行的最后一个位置 }for(int i = 1; i < n - 1; i++){dfs(board , 0 , i);//第一行除了头尾之外的位置dfs(board , m - 1, i);//最后一行除了头尾之外的位置}//dfs处理完毕后,再进行棋盘复原操作for(int i = 0; i < m; i++){for(int j = 0; j < n; j++){//如果说最后的棋盘为O 则直接进行赋值为X即可if(board[i][j] == 'O')board[i][j] = 'X';//把最后棋盘中与外界连通的标记 * 替换为 Oelse if(board[i][j] == '*')board[i][j] = 'O';}}}//寻找与外界棋盘O字符连通的区域public void dfs(char [][]board , int i , int j){//如果说越界了或者说之前被标记为'*'(已经被遍历过)或者是'X'则停止搜索if(i < 0 || j < 0 || i >= m || j >= n || board[i][j] == '*' || board[i][j] == 'X')return;board[i][j] = '*'; //标记为* 表示与外界连通并且这个位置已经被遍历过了,不再重复遍历。//上dfs(board , i - 1 , j);//下dfs(board , i + 1 , j);//左dfs(board , i , j - 1);//右dfs(board , i , j + 1);}
}
133. 克隆图
考点
哈希表、bfs
思路
思想:
bfs
,宽搜。
从起点节点开始出发,入队,出队,将该起点节点的邻接节点入队,并标记被搜索过(哈希表记录
)
再弹出当前队列的节点,入队,并继续标记其邻接节点。
依次一层一层的搜索下去,直至最后队列为空
,说明已经拷贝完图的所有节点。
代码
/*
// Definition for a Node.
class Node {public int val;public List<Node> neighbors;public Node() {val = 0;neighbors = new ArrayList<Node>();}public Node(int _val) {val = _val;neighbors = new ArrayList<Node>();}public Node(int _val, ArrayList<Node> _neighbors) {val = _val;neighbors = _neighbors;}
}
*/class Solution {public Node cloneGraph(Node node) {/*思想:bfs,宽搜。从起点节点开始出发,入队,出队,将该起点节点的邻接节点入队,并标记被搜索过。再弹出当前队列的节点,入队,并继续标记其邻接节点。依次一层一层的搜索下去,直至最后队列为空,说明已经拷贝完图的所有节点。*/if(node == null)return null;//空节点不拷贝Node []cloneNodes = new Node[110];//存储的是每一个已经拷贝(克隆)的节点,标记已被搜索过cloneNodes[node.val] = new Node(node.val);//克隆起点节点Queue<Node>queue = new LinkedList<>();//存储bfs的队列queue.offer(node); //起点节点入队Node cur; // 记录当前处理的节点while(!queue.isEmpty()){cur = queue.poll(); //从队列中获取一个待处理的节点Node cloneNode = cloneNodes[cur.val];//待处理的节点一定是克隆好的,直接获取其克隆节点for(Node neighbor : cur.neighbors){if(cloneNodes[neighbor.val] == null){//如果邻接节点未拷贝则进行拷贝cloneNodes[neighbor.val] = new Node(neighbor.val);queue.offer(neighbor);//邻接节点入队,用于下一轮的节点获取。}//克隆节点的邻居添加入遍历过的拷贝节点的邻接节点cloneNode.neighbors.add(cloneNodes[neighbor.val]);}}//返回克隆节点的记录数组即可return cloneNodes[node.val];}
}
207. 课程表
考点
bfs、拓扑排序
思路
思想: 要想修一门课程,则需要先修它的先修课程。
所以, 我们可以把他看成是一个有向无环图
。
判断最后每个点是不是入度、出度为0
的节点数
等于课程数
即可。
做法
-
先将先修课程向要修课程连一条边,同时记录要修课程的
入度
。 -
再统计每个点的入度,在
bfs
时,将待修课程节点的入度--
-
最后, 判断
入度为0
的节点数
是否等于课程数
。
等于
则说明可以完成所有课程的学习。
不等于
则说明存在环
,陷入死循环
中,无法完成课程的学习。
代码
class Solution {/*思想: 要想修一门课程,则需要先修它的先修课程。所以, 我们可以把他看成是一个有向无环图。判断最后每个点是不是入度、出度为0的节点数等于课程数即可。先将先修课程向要修课程连一条边再统计每个点的入度,在bfs搜索时,将先修课程节点的出度--最后, 入读和出度都为0,则说明可以完成所有课程的学习。最后, 判断入度、出度为0的节点数是否等于课程数。等于则说明可以完成所有课程的学习。不等于则说明存在环,陷入死循环中,无法完成课程的学习。*/public boolean canFinish(int numCourses, int[][] prerequisites) {int []indegress = new int[numCourses];List<List<Integer>>adjacency = new ArrayList<>();Queue<Integer> queue = new LinkedList<>();for(int i = 0; i < numCourses; i++){adjacency.add(new ArrayList<>());}for(int []cp : prerequisites){//要想修0必须先修1//对0而言是入度,对1而言是出度indegress[cp[0]]++;//入度++//先修课程向要修课程向连一条边adjacency.get(cp[1]).add(cp[0]);}//寻找入度为0的点开始进行拓扑排序//入度为0则说明它是可以修的课程for(int i = 0; i < numCourses; i++){if(indegress[i] == 0)queue.add(i);}while(!queue.isEmpty()){//弹出入度为0的节点,说明该课程可以被修。int pre = queue.poll();//同时课程数量--numCourses--;//遍历先修课程的节点for(int cur : adjacency.get(pre)){//出度--//如果说点cur的入度与出度都为0//则队列中添加节点cur,用于下一轮的搜索。if(--indegress[cur] == 0){queue.add(cur);}}}//最后,判断一下是不是课程数等于0//如果说课程数等于0 则代表可以完成所有课程的学习。return numCourses == 0;}
}
210. 课程表 II
考点
bfs、拓扑排序
思路
在课程表题目的基础上,多维护一个
数组
,用于记录当前弹出的节点的路径
(走过的节点)
弹出的节点是入度
为0
的节点,入度
为0
说明为已修
的先修课程,并且是先修
完的,可以按照这个顺序
来。
代码
class Solution {//在课程表题目的基础上,多维护一个数组,用于记录当前弹出的节点的路径//弹出的节点是入度为0的节点,入度为0说明为已修的先修课程,并且是先修完的,可以按照这个顺序来。public int[] findOrder(int numCourses, int[][] prerequisites) {int []indegress = new int[numCourses];//记录每个节点的入度List<List<Integer>>adjacency = new ArrayList<>();//维护一个列表用于存储边Queue<Integer>queue = new LinkedList<>();//创建队列,用于存储节点for(int i = 0; i < numCourses; i++){adjacency.add(new ArrayList<>());//每个节点先添加列表用于存连接的节点(边)}for(int []cp : prerequisites){indegress[cp[0]]++; //要修课程的入度++adjacency.get(cp[1]).add(cp[0]);//将先修课程和待修课程连一条边//用于后续遍历入度为0节点的队列将待修课程的入度--//用于下一轮的循环}//先将入度为0的节点添加入队列for(int i = 0; i < numCourses; i++){if(indegress[i] == 0)queue.add(i);}//创建数组ans,用于记录学完所有课程所安排的学习顺序。int ans[] = new int[numCourses];int index = 0;//数组下标,用于存储学完的课程while(!queue.isEmpty()){int pre = queue.poll();ans[index++]=pre;//入度为0的节点是确保能够修完的先修课程,存到结果数组中。for(int cur : adjacency.get(pre)){//将每个待修课程的入度--if(--indegress[cur] == 0){queue.add(cur);//入度为0则入队}}}//最后的结果是入度均为0//如果说某个节点的入度 > 0 , 则说明不可能修完全部课程, 存在一个环。//如[[0,1],[1,0]]//这里无法找到一个入度为0的节点,存在一个环。for(int i = 0; i < indegress.length; i++){if(indegress[i] > 0)return new int[0];//返回一个空数组即可}//等价写法如下://如果说index不等于课程数量,则说明存在入度不为0的点,也就是环。// if(index != numCourses){// return new int[0];// } return ans;//返回结果数组}
}
看到这里的小伙伴,恭喜你又掌握了一个技能👊
希望大家能取得胜利,坚持就是胜利💪
我是寸铁!我们下期再见💕
往期好文💕
保姆级教程
【保姆级教程】Windows11下go-zero的etcd安装与初步使用
【保姆级教程】Windows11安装go-zero代码生成工具goctl、protoc、go-zero
【Go-Zero】手把手带你在goland中创建api文件并设置高亮
报错解决
【Go-Zero】Error: user.api 27:9 syntax error: expected ‘:‘ | ‘IDENT‘ | ‘INT‘, got ‘(‘ 报错解决方案及api路由注意事项
【Go-Zero】Error: only one service expected goctl一键转换生成rpc服务错误解决方案
【Go-Zero】【error】 failed to initialize database, got error Error 1045 (28000):报错解决方案
【Go-Zero】Error 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)报错解决方案
【Go-Zero】type mismatch for field “Auth.AccessSecret“, expect “string“, actual “number“报错解决方案
【Go-Zero】Error: user.api 30:2 syntax error: expected ‘)‘ | ‘KEY‘, got ‘IDENT‘报错解决方案
【Go-Zero】Windows启动rpc服务报错panic:context deadline exceeded解决方案
Go面试向
【Go面试向】defer与time.sleep初探
【Go面试向】defer与return的执行顺序初探
【Go面试向】Go程序的执行顺序
【Go面试向】rune和byte类型的认识与使用
【Go面试向】实现map稳定的有序遍历的方式
相关文章:

【寸铁的刷题笔记】图论、bfs、dfs
【寸铁的刷题笔记】图论、bfs、dfs 大家好 我是寸铁👊 金三银四,图论基础结合bfs、dfs是必考的知识点✨ 快跟着寸铁刷起来!面试顺利上岸👋 喜欢的小伙伴可以点点关注 💝 🌞详见如下专栏🌞 &…...

vue2 + axios + mock.js封装过程,包含mock.js获取数据时报404状态的解决记录,带图文,超详细!!!
vue axios mock.js 以下是封装的过程,记录一下 1、首先先了解什么是mock.js的用途及特点 官网地址:Mock.js (mockjs.com) 作用:生成随机数据,拦截 Ajax 请求 优势: 2、了解axios的原理及使用 官网地址:…...

对象变更记录objectlog工具(持续跟新)
文章目录 前言演示代码演示环境引入项目项目框架操作步骤 设计介绍参考仓库 前言 系统基于mybatis-plus, springboot环境 对于重要的一些数据,我们需要记录一条记录的所有版本变化过程,做到持续追踪,为后续问题追踪提供思路。下面展示预期效果…...
平衡二叉树,二叉树的路径,左叶子之和
第六章 二叉树part04 今日内容: 110.平衡二叉树 257. 二叉树的所有路径 404.左叶子之和 110.平衡二叉树 (优先掌握递归) 给定一个二叉树,判断它是否是高度平衡的二叉树。 本题中,一棵高度平衡二叉树定义为&am…...

Sodinokibi勒索病毒最新变种,解密工具更新到2.0版本
Sodinokibi勒索病毒 Sodinokibi勒索病毒又称REvil,自从2019年6月1日,GandCrab勒索病毒运营团伙宣布停止运营之后,Sodinokibi勒索病毒马上接管了GandCrab的大部分传播渠道,同时它也被称为是GandCrab勒索病毒的“接班人”ÿ…...

css 鼠标移入放大的效果
效果 HTML <div class"img-wrap"><img class"img-item" src"../assets/1.png" alt"" srcset""></div> CSS <style lang"less" scoped> .img-wrap {/* 超出隐藏 */overflow: hidden;.img-…...
Transformer模型分布式并行通信量浅析
1.数据并行DP(朴素数据并行,Zero数据并行之后补充) O ( h 2 ∗ l ) O(h^2*l) O(h2∗l) 每台机器做完自己的梯度后需要做一次All reduce操作来累积梯度,故一个batch计算发送的数据量为每层梯度大小 h 2 h^2 h2乘以层数 l l l 优点…...
PMP考试之20240304
1.一家食品公司正在使用预测型方法开发一种新产品,该产品目前正处于测试阶段。鉴于测试反馈的性质,项目经理决定使用迭代方法。在其中一个迭代结束时,颁布了与该产品有关的新法规。项目经理接下来应该做什么? A.就项目的范围提出…...

智慧城市中的公共服务创新:让城市生活更便捷
目录 一、引言 二、智慧城市公共服务创新的实践 1、智慧交通系统 2、智慧医疗服务 3、智慧教育系统 4、智慧能源管理 三、智慧城市公共服务创新的挑战 四、智慧城市公共服务创新的前景 五、结论 一、引言 随着信息技术的迅猛发展,智慧城市已成为现代城市发…...

bert 相似度任务训练完整版
任务 之前写了一个相似度任务的版本:bert 相似度任务训练简单版本,faiss 寻找相似 topk-CSDN博客 相似度用的是 0,1,相当于分类任务,现在我们相似度有评分,不再是 0,1 了,分数为 0-5,数字越大…...

Ribbon实现Cloud负载均衡
安装Zookeeper要先安装JDK环境 解压 tar -zxvf /usr/local/develop/jdk-8u191-linux-x64.tar.gz -C /usr/local/develop 配置JAVA_HOME vim /etc/profile export JAVA_HOME/usr/local/develop/jdk1.8.0_191 export PATH$JAVA_HOME/bin:$PATH export CLASSPATH.:$JAVA_HOM…...

【UE 材质】制作加载图案(2)
在上一篇(【UE 材质】制作加载图案)基础上继续实现如下效果的加载图案 效果 步骤 1. 复制一份上一篇制作的材质并打开 2. 添加“Floor”节点向下取整 除相同的平铺数 此时的效果如下 删除如下节点 通过“Ceil”向上取整,参数“Tiling”默认…...

为啥要用C艹不用C?
在很多时候,有人会有这样的疑问 ——为什么要用C?C相对于C优势是什么? 最近两年一直在做Linux应用,能明显的感受到C带来到帮助以及快感 之前,我在文章里面提到环形队列 C语言,环形队列 环形队列到底是怎么回…...

Java:JVM基础
文章目录 参考JVM内存区域程序计数器虚拟机栈本地方法栈堆方法区符号引用与直接引用运行时常量池字符串常量池直接内存 参考 JavaGuide JVM内存区域 程序计数器 程序计数器是一块较小的内存空间,可以看做是当前线程所执行的字节码的行号指示器,各线程…...

JavaSec 基础之五大不安全组件
文章目录 不安全组件(框架)-Shiro&FastJson&Jackson&XStream&Log4jLog4jShiroJacksonFastJsonXStream 不安全组件(框架)-Shiro&FastJson&Jackson&XStream&Log4j Log4j Apache的一个开源项目,是一个基于Java的日志记录框架。 历史…...
python类的属性、方法、静态方法、静态方法类内部的调用、直接调用与实例化调用
设计者:ISDF工软未来 版本:v1.0 日期:2024/3/4 class Restaurant:餐馆类def __init__(self,restaurant_name,cuisine_type):#类的属性self.restaurant_name restaurant_nameself.cuisine_type cuisine_type# self.stregth_level 0def desc…...
haproxy集成国密ssl功能[下]
上接[haproxy集成国密ssl功能上 4. 源码修改解析 以下修改基本围绕haproxy的ssl_sock.c进行修改来展开的,为了将整个实现逻辑能够说明清楚,下述内容有部分可能就是直接摘抄haproxy的原有代码没有做任何修改,而大部分增加或者修改的内容则进行了特别的说明。 4.1 为bind指令…...

C++自学精简实践教程
一、介绍 1.1 教程特点 一篇文章从入门到就业有图有真相,有测试用例,有作业;提供框架代码,作业只需要代码填空规范开发习惯,培养设计能力 1.2 参考书 唯一参考书《C Primer 第5版》参考书下载: 蓝奏云…...

每日一题——LeetCode1572.矩阵对角线元素的和
方法一 遍历矩阵 如果矩阵中某个位置(x,y)处于对角线上,那么这个位置必定满足: xy 或 xy len-1 (len为矩阵长度) var diagonalSum function(mat) {let len mat.length;let sum 0;for (let i 0; i …...

mysql 常用命令练习
管理表格从表中查询数据从多个表查询修改数据sql变量类型 管理表格 创建一个包含三列的新表 CREATE TABLE products (id INT,name VARCHAR(255) NOT NULL,price INT DEFAULT 0,PRIMARY KEY(id) // 自增 ); 从数据库中删除表 DROP TABLE product; 向表中添加新列 ALTER TAB…...

Docker 离线安装指南
参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性,不同版本的Docker对内核版本有不同要求。例如,Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本,Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...
2024年赣州旅游投资集团社会招聘笔试真
2024年赣州旅游投资集团社会招聘笔试真 题 ( 满 分 1 0 0 分 时 间 1 2 0 分 钟 ) 一、单选题(每题只有一个正确答案,答错、不答或多答均不得分) 1.纪要的特点不包括()。 A.概括重点 B.指导传达 C. 客观纪实 D.有言必录 【答案】: D 2.1864年,()预言了电磁波的存在,并指出…...

【单片机期末】单片机系统设计
主要内容:系统状态机,系统时基,系统需求分析,系统构建,系统状态流图 一、题目要求 二、绘制系统状态流图 题目:根据上述描述绘制系统状态流图,注明状态转移条件及方向。 三、利用定时器产生时…...
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别 直接训练提示词嵌入向量的核心区别 您提到的代码: prompt_embedding = initial_embedding.clone().requires_grad_(True) optimizer = torch.optim.Adam([prompt_embedding...
Caliper 配置文件解析:config.yaml
Caliper 是一个区块链性能基准测试工具,用于评估不同区块链平台的性能。下面我将详细解释你提供的 fisco-bcos.json 文件结构,并说明它与 config.yaml 文件的关系。 fisco-bcos.json 文件解析 这个文件是针对 FISCO-BCOS 区块链网络的 Caliper 配置文件,主要包含以下几个部…...
OpenLayers 分屏对比(地图联动)
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 地图分屏对比在WebGIS开发中是很常见的功能,和卷帘图层不一样的是,分屏对比是在各个地图中添加相同或者不同的图层进行对比查看。…...
蓝桥杯 冶炼金属
原题目链接 🔧 冶炼金属转换率推测题解 📜 原题描述 小蓝有一个神奇的炉子用于将普通金属 O O O 冶炼成为一种特殊金属 X X X。这个炉子有一个属性叫转换率 V V V,是一个正整数,表示每 V V V 个普通金属 O O O 可以冶炼出 …...

短视频矩阵系统文案创作功能开发实践,定制化开发
在短视频行业迅猛发展的当下,企业和个人创作者为了扩大影响力、提升传播效果,纷纷采用短视频矩阵运营策略,同时管理多个平台、多个账号的内容发布。然而,频繁的文案创作需求让运营者疲于应对,如何高效产出高质量文案成…...
Java编程之桥接模式
定义 桥接模式(Bridge Pattern)属于结构型设计模式,它的核心意图是将抽象部分与实现部分分离,使它们可以独立地变化。这种模式通过组合关系来替代继承关系,从而降低了抽象和实现这两个可变维度之间的耦合度。 用例子…...

STM32---外部32.768K晶振(LSE)无法起振问题
晶振是否起振主要就检查两个1、晶振与MCU是否兼容;2、晶振的负载电容是否匹配 目录 一、判断晶振与MCU是否兼容 二、判断负载电容是否匹配 1. 晶振负载电容(CL)与匹配电容(CL1、CL2)的关系 2. 如何选择 CL1 和 CL…...