钥匙和房间

本文参考代码随想录

有 N 个房间,开始时你位于 0 号房间。每个房间有不同的号码:0,1,2,…,N-1,并且房间里可能有一些钥匙能使你进入下一个房间。

在形式上,对于每个房间 i 都有一个钥匙列表 rooms[i],每个钥匙 rooms[i][j] 由 [0,1,…,N-1] 中的一个整数表示,其中 N = rooms.length。 钥匙 rooms[i][j] = v 可以打开编号为 v 的房间。

最初,除 0 号房间外的其余所有房间都被锁住。

你可以自由地在房间之间来回走动。

如果能进入每个房间返回 true,否则返回 false。

示例 1:

输入: [[1],[2],[3],[]]
输出: true
解释: 我们从 0 号房间开始,拿到钥匙 1。 之后我们去 1 号房间,拿到钥匙 2。 然后我们去 2 号房间,拿到钥匙 3。 最后我们去了 3 号房间。 由于我们能够进入每个房间,我们返回 true。
示例 2:

输入:[[1,3],[3,0,1],[2],[0]]
输出:false
解释:我们不能进入 2 号房间

思路

本题是一个有向图搜索全路径的问题。 只能用深搜(DFS)或者广搜(BFS)来搜。

dfs

classSolution:defcanVisitAllRooms(self,rooms:List[List[int]])->bool:defdfs(rooms,key,visited):ifvisited[key]==True:returnvisited[key]=Truekeys=rooms[key]fornext_keyinkeys:dfs(rooms,next_key,visited)visited=[False]*len(rooms)dfs(rooms,0,visited)forvinvisited:ifnotv:returnFalsereturnTrue

bfs

classSolution:defcanVisitAllRooms(self,rooms:List[List[int]])->bool:defbfs(start,rooms,visited):q=collections.deque()q.append(start)visited[start]=Truewhileq:cur=q.popleft()next_keys=rooms[cur]fornext_keyinnext_keys:ifvisited[next_key]==False:visited[next_key]=Trueq.append(next_key)visited=[False]*len(rooms)bfs(0,rooms,visited)forvinvisited:ifnotv:returnFalsereturnTrue

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

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

相关文章

IAR使用教程:优化嵌入式C代码的操作指南

如何用IAR榨干MCU性能?一位嵌入式老手的实战优化笔记最近在调试一个低功耗传感器项目时,客户突然提出“电池寿命必须延长30%”。我看了看当前固件:Flash用了快300KB,SRAM占用接近80%,主循环执行时间也偏长。硬件已经定…

大模型推理过程内存占用(动态)

阿里社区博客(重点在transformer的激活值参数量估计):https://developer.aliyun.com/article/1496103 推理时显存占用(GitHub): https://github.com/Hoper-J/I-Guide-and-Demos-zh_CN/blob/master/Guide/07.%20%E6%8E%A2%E7%A9%…

u8g2字体编码与字符映射关系通俗解释

u8g2字体编码与字符映射:从“乱码”到清晰显示的底层逻辑 你有没有遇到过这样的场景?在STM32或ESP32上驱动一块OLED屏,信心满满地调用 u8g2_DrawStr() 打印一句中文“温度25C”,结果屏幕上却只出现几个方框、问号,甚…

AD23新增元件库资源盘点:与AD20的生态扩展对比

AD23元件库生态跃迁:从“建库”到“治库”的工程革命你有没有经历过这样的场景?深夜赶板,原理图画到一半,发现缺一个关键电源芯片的封装——查遍本地库、论坛、第三方网站,最终找到一个名字像模像样但引脚顺序反了的Pc…

单词接龙问题

本文参考代码随想录 字典 wordList 中从单词 beginWord 和 endWord 的 转换序列 是一个按下述规格形成的序列: 序列中第一个单词是 beginWord 。 序列中最后一个单词是 endWord 。 每次转换只能改变一个字母。 转换过程中的中间单词必须是字典 wordList 中的单词。…

STM32最小系统板Keil5下载实操从零实现

从零搭建STM32最小系统板:Keil5下载实战全解析 你是否也经历过这样的时刻——电路焊好了,代码写完了,满怀期待地点击“Download”,结果 Keil 弹出一串红字:“No target connected”? 别急,这几…

信息化在线教学平台信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】

💡实话实说:用最专业的技术、最实惠的价格、最真诚的态度服务大家。无论最终合作与否,咱们都是朋友,能帮的地方我绝不含糊。买卖不成仁义在,这就是我的做人原则。摘要 随着信息技术的快速发展,教育行业正逐…

SpringBoot+Vue 在线宠物用品交易网站平台完整项目源码+SQL脚本+接口文档【Java Web毕设】

💡实话实说:用最专业的技术、最实惠的价格、最真诚的态度服务大家。无论最终合作与否,咱们都是朋友,能帮的地方我绝不含糊。买卖不成仁义在,这就是我的做人原则。摘要 随着互联网技术的快速发展,电子商务已…

冗余连接问题

本文参考代码随想录 树可以看成是一个连通且 无环 的 无向 图。 给定往一棵 n 个节点 (节点值 1~n) 的树中添加一条边后的图。添加的边的两个顶点包含在 1 到 n 中间,且这条附加的边不属于树中已存在的边。图的信息记录于长度为 n 的二维数组 edges &am…

MOSFET驱动电路设计从零实现:基于IR2110

从零搭建MOSFET驱动电路:IR2110实战全解析你有没有遇到过这样的情况——明明MCU输出了正确的PWM信号,但MOSFET却发热严重、效率低下,甚至莫名其妙烧毁?问题很可能出在驱动电路上。在功率电子系统中,MOSFET是核心开关器…

SpringBoot+Vue 论坛网站平台完整项目源码+SQL脚本+接口文档【Java Web毕设】

💡实话实说:用最专业的技术、最实惠的价格、最真诚的态度服务大家。无论最终合作与否,咱们都是朋友,能帮的地方我绝不含糊。买卖不成仁义在,这就是我的做人原则。摘要 随着互联网技术的快速发展,在线论坛平…

AI SaaS产品的数据管道架构:实时处理方案

AI SaaS产品的数据管道架构:实时处理方案关键词:AI SaaS产品、数据管道架构、实时处理、数据流动、架构设计摘要:本文聚焦于AI SaaS产品的数据管道架构实时处理方案。首先介绍了相关背景知识,让大家明白为什么要关注实时处理以及预…

LVGL移植入门:在STM32上运行GUI的实战案例

在STM32上跑LVGL:从零开始打造嵌入式GUI实战指南你有没有遇到过这样的场景?项目做了一半,客户突然说:“能不能加个触摸屏,界面做得漂亮点?”——传统段码屏瞬间不够看了。这时候,一个轻量、免费…

冗余连接II

本文参考代码随想录 在本问题中,有根树指满足以下条件的 有向 图。该树只有一个根节点,所有其他节点都是该根节点的后继。该树除了根节点之外的每一个节点都有且只有一个父节点,而根节点没有父节点。 输入一个有向图,该图由一个有…

【毕业设计】SpringBoot+Vue+MySQL 游戏销售平台平台源码+数据库+论文+部署文档

💡实话实说:用最专业的技术、最实惠的价格、最真诚的态度服务大家。无论最终合作与否,咱们都是朋友,能帮的地方我绝不含糊。买卖不成仁义在,这就是我的做人原则。摘要 随着互联网技术的快速发展和数字娱乐产业的蓬勃兴…

SpringBoot+Vue 汽车票网上预订系统管理平台源码【适合毕设/课设/学习】Java+MySQL

💡实话实说: 有自己的项目库存,不需要找别人拿货再加价,所以能给到超低价格。 摘要 随着互联网技术的快速发展,传统汽车票销售模式已无法满足现代旅客的需求。线下购票存在排队时间长、信息不对称、票源紧张等问题&am…

LCD12864并行接口入门必看:初始化代码详解

从零点亮一块 LCD12864:并行接口初始化全解析你有没有遇到过这样的情况?电路接得整整齐齐,代码烧录成功,背光一亮,结果屏幕却“黑如墨、白如纸”——啥也不显示。反复检查引脚、重写初始化函数,还是没反应。…

虚拟串口配置入门必看:手把手搭建通信环境

虚拟串口配置实战指南:从零搭建高效通信链路 你有没有遇到过这样的场景? 手头没有目标硬件,但上位机程序已经写好了,急着要验证 Modbus 协议逻辑;或者 CI 测试流水线跑得好好的,却因为服务器没串口而卡住…

AI应用架构师从0到1:AI虚拟培训项目的团队协作与角色分工

AI应用架构师从0到1:AI虚拟培训项目的团队协作与角色分工 1. 引入与连接 1.1 引人入胜的开场 想象一下,在未来的职场中,新员工无需再在冗长的线下培训课堂中昏昏欲睡,而是戴上虚拟现实(VR)设备,瞬间置身于高度仿真的工作场景中,与栩栩如生的虚拟导师进行互动,接受定…

OTG连接键盘鼠标:提升移动办公效率

用一根线把手机变电脑:OTG连接键盘鼠标的实战全解析你有没有过这样的经历?在机场候机时突然要改一份PPT,手指在虚拟键盘上反复敲错字;或者用平板远程登录服务器,却因为没有鼠标而无法精准选中命令行。这些场景下&#…