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

LeetCode图算法实战:从省份数量到猫和老鼠的5种必会解法

LeetCode图算法精要5种核心解法与实战技巧1. 图算法基础与高频问题分类图算法是算法面试中的核心考察点掌握常见解题模式能显著提升解题效率。我们将LeetCode高频图问题分为以下几类连通性问题省份数量、封闭岛屿统计路径问题最短路径、最大路径价值拓扑排序课程安排、继承顺序并查集应用冗余连接、保证图可遍历特殊博弈问题猫和老鼠# 邻接表表示法示例 graph { 0: [1, 2], 1: [0, 3], 2: [0], 3: [1] }关键指标对比算法类型时间复杂度空间复杂度适用场景DFS/BFSO(VE)O(V)连通性、路径查找DijkstraO(ElogV)O(V)带权最短路径拓扑排序O(VE)O(V)依赖关系排序并查集O(α(n))O(n)动态连通性2. 深度优先搜索的进阶应用DFS不仅是简单的遍历工具通过巧妙设计能解决复杂图问题封闭岛屿统计技巧边界陆地标记为非封闭采用染色法标记已访问节点使用标志位避免提前终止递归def closedIsland(grid): def dfs(x, y): if x 0 or y 0 or x len(grid) or y len(grid[0]): return False if grid[x][y] ! 0: return True grid[x][y] 1 # 标记为已访问 res True for dx, dy in directions: res dfs(xdx, ydy) return res directions [(-1,0),(1,0),(0,-1),(0,1)] count 0 for i in range(len(grid)): for j in range(len(grid[0])): if grid[i][j] 0 and dfs(i, j): count 1 return count易错点警示忘记处理边界条件导致错误标记递归时未及时更新访问状态错误使用或运算替代与运算判断封闭性3. 并查集的优化实践并查集是解决连通性问题的利器优化版本能显著提升性能带权并查集实现class UnionFind: def __init__(self, size): self.parent list(range(size)) self.rank [1] * size def find(self, x): if self.parent[x] ! x: self.parent[x] self.find(self.parent[x]) return self.parent[x] def union(self, x, y): x_root self.find(x) y_root self.find(y) if x_root y_root: return False if self.rank[x_root] self.rank[y_root]: self.parent[x_root] y_root else: self.parent[y_root] x_root if self.rank[x_root] self.rank[y_root]: self.rank[x_root] 1 return True实战案例省份数量def findCircleNum(isConnected): n len(isConnected) uf UnionFind(n) for i in range(n): for j in range(i1, n): if isConnected[i][j] 1: uf.union(i, j) return len(set(uf.find(i) for i in range(n)))性能优化技巧路径压缩使find操作接近O(1)按秩合并保持树结构平衡即时更新连通分量计数4. 拓扑排序的典型场景拓扑排序特别适合处理依赖关系问题以下是关键实现细节课程安排问题解法def canFinish(numCourses, prerequisites): adj [[] for _ in range(numCourses)] indegree [0] * numCourses for dest, src in prerequisites: adj[src].append(dest) indegree[dest] 1 queue [i for i in range(numCourses) if indegree[i] 0] count 0 while queue: node queue.pop() count 1 for neighbor in adj[node]: indegree[neighbor] - 1 if indegree[neighbor] 0: queue.append(neighbor) return count numCourses并行课程III的DP解法def minimumTime(n, relations, time): adj [[] for _ in range(n1)] rev_adj [[] for _ in range(n1)] indegree [0]*(n1) for prev, next_ in relations: adj[prev].append(next_) rev_adj[next_].append(prev) indegree[next_] 1 dp [0]*(n1) queue [i for i in range(1,n1) if indegree[i]0] for node in queue: dp[node] time[node-1] res 0 while queue: node queue.pop(0) res max(res, dp[node]) for neighbor in adj[node]: max_prev 0 for prev in rev_adj[neighbor]: max_prev max(max_prev, dp[prev]) dp[neighbor] max_prev time[neighbor-1] indegree[neighbor] - 1 if indegree[neighbor] 0: queue.append(neighbor) return res5. 状态压缩与记忆化搜索对于复杂博弈问题如猫和老鼠状态压缩是必要手段关键实现要素定义三维状态 (回合数, 猫位置, 鼠位置)使用记忆化存储已计算状态考虑平局条件的终止判断def catMouseGame(graph): n len(graph) memo [[[-1]*n for _ in range(n)] for __ in range(2*n)] def dfs(k, a, b): if k 2*n*n: return 0 if a 0: return 1 if a b: return 2 if memo[k][a][b] ! -1: return memo[k][a][b] if k % 2 0: # 鼠的回合 draw False for nei in graph[a]: res dfs(k1, nei, b) if res 1: memo[k][a][b] 1 return 1 if res 0: draw True memo[k][a][b] 0 if draw else 2 else: # 猫的回合 draw False for nei in graph[b]: if nei 0: continue res dfs(k1, a, nei) if res 2: memo[k][a][b] 2 return 2 if res 0: draw True memo[k][a][b] 0 if draw else 1 return memo[k][a][b] return dfs(0, 1, 2)优化方向使用位运算压缩状态表示提前终止不必要的搜索分支对称性剪枝减少状态空间掌握这五种核心解法后面对LeetCode中90%的图算法问题都能找到解决思路。实际解题时需要根据问题特点灵活组合这些方法并注意边界条件的处理。

相关文章:

LeetCode图算法实战:从省份数量到猫和老鼠的5种必会解法

LeetCode图算法精要:5种核心解法与实战技巧 1. 图算法基础与高频问题分类 图算法是算法面试中的核心考察点,掌握常见解题模式能显著提升解题效率。我们将LeetCode高频图问题分为以下几类: 连通性问题:省份数量、封闭岛屿统计路径问…...

小程序启动优化:冷热启动机制与强制更新策略解析

1. 小程序启动机制:冷启动与热启动的底层逻辑 第一次打开小程序时,页面加载总感觉有点慢?而第二次打开却快如闪电?这背后就是冷启动和热启动的差异在起作用。作为开发者,理解这两种启动方式的运行机制,是优…...

Exchange Server 2019用户必看:如何零成本升级到订阅版(附详细步骤)

Exchange Server 2019零成本升级订阅版全流程指南 对于仍在运行Exchange Server 2019的企业IT团队来说,2025年将迎来一个关键转折点。微软最新推出的订阅版解决方案,不仅延续了企业级邮件系统的核心功能,更通过灵活的许可模式降低了长期使用成…...

虚拟控制器驱动技术革新:ViGEmBus从基础配置到深度开发的实战指南

虚拟控制器驱动技术革新:ViGEmBus从基础配置到深度开发的实战指南 【免费下载链接】ViGEmBus 项目地址: https://gitcode.com/gh_mirrors/vig/ViGEmBus 在游戏开发与外设兼容领域,虚拟控制器技术正成为连接多样化输入设备与标准化系统接口的关键…...

ThinkPHP8.0与PHP8.1兼容性实测:这些新特性让你的开发效率翻倍

ThinkPHP8.0与PHP8.1深度兼容指南:解锁性能飞跃的实战密码 当PHP8.1的JIT编译器遇上ThinkPHP8.0的现代化架构,会产生怎样的化学反应?作为长期深耕企业级PHP开发的实践者,我完整经历了从PHP7.4到8.1的升级历程,特别是在…...

一站式毕业助手:选题、写作、答辩全搞定

作为一个去年从“选题迷茫”到“答辩优秀”一路摸爬滚打过来的老学长,今天我把亲测好用的5款论文神器一次性分享出来。不整虚的,只说怎么用、解决什么问题。希望能帮你少熬几个大夜,顺利上岸。一、写不出?这两款帮你“搭框架”痛点…...

解决OSX-KVM打印服务问题:从驱动安装到网络共享完整指南

解决OSX-KVM打印服务问题:从驱动安装到网络共享完整指南 【免费下载链接】OSX-KVM Run macOS on QEMU/KVM. With OpenCore Big Sur Monterey Ventura support now! Only commercial (paid) support is available now to avoid spammy issues. No Mac system is r…...

教育SRC漏洞平台实战:从注册到漏洞提交的全流程解析

教育SRC漏洞平台实战指南:从入门到精通的全方位解析 在数字化教育快速发展的今天,教育行业网络安全问题日益凸显。作为安全研究人员,参与教育SRC(安全应急响应中心)漏洞平台不仅能提升个人技术能力,还能为教…...

光伏系统并网最头疼的就是太阳说变脸就变脸。咱们今天要聊的Simulink模型,就是让储能系统当个靠谱队友——光照突变时它能马上顶上,把并网功率稳得像条直线

Simulink光伏储能并网控制模型 微网,光储系统并网运行 光照强度发生改变时,储能可以有效配合光伏进行恒定功率并网,平抑波动,实现削峰填谷。 光伏最大功率点采用电导增量法 通俗易懂先看光伏这边的核心算法,电导增量法…...

vulmap漏洞扫描工具实战:从安装到批量检测Web中间件的完整指南

Vulmap漏洞扫描实战:高效检测Web中间件安全的全流程指南 在网络安全领域,Web中间件的漏洞往往是攻击者最常利用的入口点。面对层出不穷的安全威胁,安全从业者需要掌握高效精准的漏洞检测工具。本文将带您深入掌握Vulmap这一轻量级但功能强大的…...

高并发下的列表乱序与文档同步

一、整体工作概述 今天主要完成了一点bug修复,高并发点击的时候列表会乱序,以及ai coding实现文档的CRUD,同时文档列表要同步渲染。 这一大块是ai写的,我只是看懂了代码,整体技术难度不高,而且一部分实现方…...

uniapp集成支付宝授权登录全流程指南(附iOS/Android适配方案)

uniapp集成支付宝授权登录全流程指南(附iOS/Android适配方案) 在移动应用开发中,第三方登录已经成为提升用户体验的重要功能之一。支付宝作为国内主流的支付平台,其授权登录功能被广泛应用于各类APP中。本文将详细介绍如何在unia…...

避坑指南:STM32F407开发中那些容易翻车的细节(GPIO消抖/FSMC配置/CAN总线调试)

STM32F407实战避坑手册:GPIO消抖、FSMC配置与CAN总线调试精要 从事嵌入式开发多年,我见过太多工程师在STM32F407项目开发中反复踩同样的坑。本文将聚焦三个最容易出问题的技术点——GPIO消抖、FSMC接口配置和CAN总线调试,结合真实项目案例&am…...

OSX-KVM PCI设备直通详解:从网卡到GPU全攻略

OSX-KVM PCI设备直通详解:从网卡到GPU全攻略 【免费下载链接】OSX-KVM Run macOS on QEMU/KVM. With OpenCore Big Sur Monterey Ventura support now! Only commercial (paid) support is available now to avoid spammy issues. No Mac system is required. …...

3分钟搞定网易云音乐插件安装:BetterNCM Installer终极指南

3分钟搞定网易云音乐插件安装:BetterNCM Installer终极指南 【免费下载链接】BetterNCM-Installer 一键安装 Better 系软件 项目地址: https://gitcode.com/gh_mirrors/be/BetterNCM-Installer BetterNCM Installer是网易云音乐PC版客户端的最佳插件管理器安…...

从硬件到软件:用示波器抓取分析MCU启动波形的完整教程

从硬件到软件:用示波器抓取分析MCU启动波形的完整教程 当一块微控制器(MCU)从冷启动到正常运行,其内部经历了一系列精密的"唤醒仪式"。对于硬件开发者而言,能够亲眼目睹这一过程就像获得了诊断系统健康的X光…...

【企业级API协议选型终极指南】:基于金融/物联网/实时音视频三大场景的MCP落地决策树

第一章:MCP协议与传统REST API性能对比概览MCP(Message-Centric Protocol)是一种面向高吞吐、低延迟场景设计的二进制消息协议,其核心理念是通过紧凑序列化、连接复用与无状态批量交互,显著降低网络往返与解析开销。相…...

GitHub Linguist自动化测试框架:CI环境中的集成方法

GitHub Linguist自动化测试框架:CI环境中的集成方法 【免费下载链接】linguist Language Savant. If your repositorys language is being reported incorrectly, send us a pull request! 项目地址: https://gitcode.com/GitHub_Trending/li/linguist GitHu…...

基于多种天气因素的光伏电站太阳能辐射量预测系统——采用人工神经网络与离线优化算法

MATLAB代码:考虑多种天气条件下光伏电站太阳能辐射量预测 关键词:辐射量预测 光伏预测 多种天气因素 参考文档:《Solar Radiation Prediction and Energy Allocation for Energy Harvesting Base Stations》 仿真平台:MATLABCPLE…...

别再手动画图了!用Coze+TreeMind,5分钟搞定ISO标准流程图和思维导图

告别低效绘图:AI双引擎如何重塑你的视觉化工作流 在知识经济时代,信息可视化能力已成为职场核心竞争力。国际数据公司(IDC)研究显示,专业工作者平均每周耗费4.7小时在图表制作上,其中72%的时间用于机械性的…...

Kubernetes 1.28 集群架构深入解析:从基础到企业级部署

文章目录 🌐 Kubernetes 1.28 集群架构深度解析:从基础到企业级部署 ✅ 前言:云原生时代的操作系统 一、Kubernetes 1.28 集群架构全景图 1.1 核心设计哲学:声明式、期望状态、控制器模式 1.2 架构演进:从单节点到全球分布式集群 1.3–1.5 架构组件全景(统一图谱) 二、…...

[SWPUCTF 2025 秋季新生赛]ezez_include两种解题思路

方法一:日志文件包含一开始考虑的是文件上传,dirsearch扫描出来有upload页面结果根据响应页面这个版本的文件上传漏洞完全做不出来,服务器解析不了换个思路,文件包含利用日志包含漏洞什么是日志包含漏洞:就是把恶意代码…...

Spring Boot + Vue3 社区生鲜团购系统源码(Java Web全栈开发)

温馨提示:文末有联系方式全新升级版生鲜团购系统源码 本套Java Web全栈项目基于Spring Boot后端框架与Vue3前端框架深度整合,专为社区生鲜团购场景定制开发,代码结构清晰、注释完整、功能完备,非网上泛滥的廉价模板,品…...

OpenClaw+LibTV = 真正意义的一站式短剧自动生成

当你的手中有了OpenClaw,并为他创建了机器人,用它做了很多纯文本的工作,还不知足?你想着去用它接入豆包生成图片,接入Seedance生成视频,巴拉巴拉折腾好一顿,光是网站都要打开好多个,…...

CH32V307 - SPI基础时序详解

目录 前言 一、SPI概念 1.接口说明 2.时序实现 3.应用方法 二、基础时序实现代码 1.IO口读写操作 2.SPI对应IO口初始化 3.SPI开始时序 4.SPI终止时序 5.SPI交换一个字节 三、函数调用 四、实验现象 五、完整代码 main.c SPI.c SPI.h Key.c / Key.h LED.c / L…...

终极指南:如何使用Legacy iOS Kit让旧iPhone/iPad重获新生

终极指南:如何使用Legacy iOS Kit让旧iPhone/iPad重获新生 【免费下载链接】Legacy-iOS-Kit An all-in-one tool to downgrade/restore, save SHSH blobs, and jailbreak legacy iOS devices 项目地址: https://gitcode.com/gh_mirrors/le/Legacy-iOS-Kit 你…...

All-In-One Sandbox:Agent自动化任务的统一执行环境

All-In-One Sandbox:Agent自动化任务的统一执行环境 当你的Agent需要同时操作浏览器、执行代码、运行Shell命令来完成一个任务时,是否曾陷入这样的困境:浏览器下载的文件要上传到云存储,代码沙箱才能读取;代码生成的结果又要重新上传,供下一个工具使用……这种“文件共享…...

上位机开发初体验|第一个项目从 0 到 1:项目创建与整体 UI 布局

作为上位机开发的新手,我的第一个项目从基础的项目搭建和 UI 布局开始入手,这一步也是整个项目的基础,做好窗体、容器、控件的基础样式配置,能为后续的功能开发打下整洁的框架。以下是我整理的详细操作步骤,亲测实用&a…...

最新!OpenClaw 2026年云端与本地Windows11、macOS、Linux系统安装及使用零技术步骤

最新!OpenClaw 2026年云端与本地Windows11、macOS、Linux系统安装及使用零技术步骤。本文面向零基础用户,完整说明在轻量服务器与本地Windows11、macOS、Linux系统中部署OpenClaw(Clawdbot)的流程,包含环境配置、服务启…...

API平台选型指南:从RapidAPI到幂简集成,如何为你的项目精准匹配?

1. 为什么API平台选型如此重要? 想象一下你正在开发一个本地生活应用,需要整合支付、地图和AI能力。如果每个功能都从零开发,光是支付系统可能就要耗费半年时间。而通过API平台,你可以在几小时内接入成熟的支付宝接口,…...