【寸铁的刷题笔记】图论、bfs、dfs

【寸铁的刷题笔记】图论、bfs、dfs

大家好 我是寸铁👊
金三银四图论基础结合bfsdfs是必考的知识点✨
快跟着寸铁刷起来!面试顺利上岸👋
喜欢的小伙伴可以点点关注 💝


🌞详见如下专栏🌞

🍀🍀🍀寸铁的刷题笔记🍀🍀🍀


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围绕的区域,并将这块区域中的所有的'OX进行填充。

转换问题

那么怎么样去寻找所有被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节点数等于课程数即可。

做法

  1. 先将先修课程向要修课程连一条边,同时记录要修课程的入度

  2. 再统计每个点的入度,在bfs时,将待修课程节点的入度--

  3. 最后, 判断入度为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稳定的有序遍历的方式

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/265526.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

我在代码随想录|写代码Day27 | 贪心算法 | 122.买卖股票的最佳时机 II,55. 跳跃游戏, 45.跳跃游戏 II

&#x1f525;博客介绍&#xff1a; 27dCnc &#x1f3a5;系列专栏&#xff1a; <<数据结构与算法>> << 算法入门>> << C项目>> &#x1f3a5; 当前专栏: <<数据结构与算法>> 专题 : 数据结构帮助小白快速入门算法 &…

代码随想录算法训练营29期|day64 任务以及具体安排

第十章 单调栈part03 有了之前单调栈的铺垫&#xff0c;这道题目就不难了。 84.柱状图中最大的矩形class Solution {int largestRectangleArea(int[] heights) {Stack<Integer> st new Stack<Integer>();// 数组扩容&#xff0c;在头和尾各加入一个元素int [] ne…

算法沉淀——动态规划之路径问题(leetcode真题剖析)

算法沉淀——动态规划之路径问题 01.不同路径02.不同路径 II03.珠宝的最高价值04.下降路径最小和05.最小路径和06.地下城游戏 01.不同路径 题目链接&#xff1a;https://leetcode.cn/problems/unique-paths/ 一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图…

鸿运(通天星CMSV6车载)主动安全监控云平台敏感信息泄露漏洞

文章目录 前言声明一、系统简介二、漏洞描述三、影响版本四、漏洞复现五、修复建议 前言 鸿运主动安全监控云平台实现对计算资源、存储资源、网络资源、云应用服务进行7*24小时全时区、多地域、全方位、立体式、智能化的IT运维监控&#xff0c;保障IT系统安全、稳定、可靠运行…

Mycat核心教程--Mycat 监控工具【四】

Mycat核心教程--Mycat 监控工具 九、Mycat 监控工具9.1.Mycat-web 简介9.2.Mycat-web 配置使用9.2.1.ZooKeeper 安装【上面有】9.2.2.Mycat-web 安装9.2.2.1.下载安装包9.2.2.2.安装包拷贝到Linux系统/opt目录下&#xff0c;并解压9.2.2.3.拷贝mycat-web文件夹到/usr/local目录…

堆和堆排序【数据结构】

目录 一、堆1. 堆的存储定义2. 初始化堆3. 销毁堆4. 堆的插入向上调整算法 5. 堆的删除向下调整算法 6. 获取堆顶数据7. 获取堆的数据个数8. 堆的判空 二、Gif演示三、 堆排序1. 堆排序(1) 建大堆(2) 排序 2.Topk问题 四、完整代码1.堆的代码Heap.cHeap.htest.c 2. 堆排序的代码…

最新IE跳转Edge浏览器解决办法(2024.2.26)

最新IE跳转Edge浏览器解决办法&#xff08;2024.2.26&#xff09; 1. IE跳转原因1.1. 原先解决办法1.2. 最新解决办法1.3. 最后 1. IE跳转原因 关于IE跳转问题是由于在2023年2月14日&#xff0c;微软正式告别IE浏览器&#xff0c;导致很多使用Windows10系统的电脑在打开IE浏览…

树莓派 关闭低电压闪电报警和文字报警

关闭低电压闪电图标报警 方法&#xff1a; sudo nano /boot/config.txt在末尾加上 avoid_warnings1重启就可以了 关闭文字报警 方法&#xff1a; sudo apt remove lxplug-ptbatt然后重启就可以了

【论文阅读】基于人工智能目标检测与跟踪技术的过冷流沸腾气泡特征提取

Bubble feature extraction in subcooled flow boiling using AI-based object detection and tracking techniques 基于人工智能目标检测与跟踪技术的过冷流沸腾气泡特征提取 期刊信息&#xff1a;International Journal of Heat and Mass Transfer 2024 级别&#xff1a;EI检…

SpringCloud-Gateway解决跨域问题

Spring Cloud Gateway是一个基于Spring Framework的微服务网关&#xff0c;用于构建可扩展的分布式系统。在处理跨域问题时&#xff0c;可以通过配置网关来实现跨域资源共享&#xff08;CORS&#xff09;。要解决跨域问题&#xff0c;首先需要在网关的配置文件中添加相关的跨域…

SNMP简介

定义 简单网络管理协议SNMP&#xff08;Simple Network Management Protocol&#xff09;是广泛应用于TCP/IP网络的网络管理标准协议。SNMP提供了一种通过运行网络管理软件的中心计算机&#xff08;即网络管理工作站&#xff09;来管理设备的方法。SNMP的特点如下&#xff1a;…

Python爬虫获取淘宝商品详情页数据|实现自动化采集商品信息

要实现自动化采集淘宝商品详情页数据&#xff0c;可以使用Python的第三方库如requests和BeautifulSoup。以下是一个简单的示例&#xff1a; Taobao.item_get-获得淘宝商品详情数据接口返回值说明 1.请求方式:HTTP POST &#xff1b;复制Taobaoapi2014获取APISDK文件。 2.请求…

如何让网页APP化 渐进式Web应用(PWA)

前言 大家上网应该发现有的网页说可以安装对应应用&#xff0c;结果这个应用好像就是个web&#xff0c;不像是应用&#xff0c;因为这里采用了PWA相关技术。 PWA&#xff0c;全称为渐进式Web应用&#xff08;Progressive Web Apps&#xff09;&#xff0c;是一种可以提供类似…

pytest如何在类的方法之间共享变量?

在pytest中&#xff0c;setup_class是一个特殊的方法&#xff0c;它用于在类级别的测试开始之前设置一些初始化的状态。这个方法会在类中的任何测试方法执行之前只运行一次。 当你在setup_class中使用self来修改类属性时&#xff0c;你实际上是在修改类的一个实例属性。在Pyth…

开源现场总线协议栈(ethercat、ethernet/ip、opc ua、profinet、canopen、modbus)

ecat主站及其相关&#xff1a; 1.soem&#xff1a;GitHub - OpenEtherCATsociety/SOEM: Simple Open Source EtherCAT MasterSimple Open Source EtherCAT Master. Contribute to OpenEtherCATsociety/SOEM development by creating an account on GitHub.https://github.com/…

Rust升级慢,使用国内镜像进行加速

背景 rustup 是 Rust 官方的跨平台 Rust 安装工具&#xff0c;国内用户使用rustup update的时候&#xff0c;网速非常慢&#xff0c;可以使用国内的阿里云镜像源来进行加速 0x01 配置方法 1. Linux与Mac OS用户配置环境变量 修改~/.bash_profile文件添加如下内容&#xff1…

科技论文编写思路

科技论文编写思路 1.基本框架2.课题可行性评估1.研究目标和意义2.研究方法和技术3.可行性和可操作性4.风险和不确定性5.经济性和资源投入6.成果预期和评估 3.写作思路4.利用AI读论文5.实验流程 1.基本框架 IntroductionRelated worksMethodExperiment and analysisDiscussionC…

【Git教程】(五)分支 —— 并行式开发,分支相关操作(创建、切换、删除)~

Git教程 分支 1️⃣ 并行式开发2️⃣ 修复旧版本中的 bug3️⃣ 分支4️⃣ 当前活跃分支5️⃣ 重置分支指针6️⃣ 删除分支7️⃣ 清理提交对象&#x1f33e; 总结 对于版本提交为什么不能依次进行&#xff0c;以便形成一条直线型的提交历史记录&#xff0c;我们认为有 以下两个…

swagger-ui.html报错404,解决办法

swagger-ui.html报错404,解决办法&#xff01;现在后端开发项目中&#xff0c;为了节省时间&#xff0c;使用swagger插件&#xff0c;可以方便的快捷生成接口文档。但是如果你在请求前端页面路径比如&#xff1a;http://127.0.0.1:7777/swagger-ui.html。找不到。那是因为你的配…

深度学习基础(一)神经网络基本原理

之前的章节我们初步介绍了机器学习相关基础知识&#xff0c;目录如下&#xff1a; 机器学习基础&#xff08;一&#xff09;理解机器学习的本质-CSDN博客 机器学习基础&#xff08;二&#xff09;监督与非监督学习-CSDN博客 机器学习基础&#xff08;四&#xff09;非监督学…