【LeetCode75】第四十三题 钥匙和房间

目录

题目:

示例:

分析:

代码:


题目:

示例:

分析:

给我们一个数组,表示对应的房间里拥有能开启的对应索引号的钥匙。

一开始我们只能进入0号房间,也就是数组里索引号为0的位置。数组索引为0的位置里的元素就是我们能拿到的钥匙,可以开启对应房间号的门。我们可以再次进入到这些能够进入的房间,再拿到房间里的钥匙......

问我们最后能不能进入到所有的房间。

那么这道题是一眼就能看出来要使用BFS或是DFS来解题的了。

那我个人比较喜欢DFS,那我就用DFS来做。

首先我们先定义一个长度为房间数量的数组,元素类型为bool类型,用来表示我们能否进入到对应的房间。

一开始我们是只能进入到0号房间,也只能拿到0号房间里的钥匙

接着我们开始递归,在递归里遍历0号房间的钥匙,如果钥匙对应的房间我们是之前就可以进入的,那么我们跳过这把钥匙,因为该房间我们现在或者是之前已经递归过了,为了剪枝,我们就跳过这把钥匙。

如果钥匙对应的房间我们之前没有进入过,那么我们将一开始定义的那个数组中对应的位置置为true表示我们可以进入。再拿到这个房间里的钥匙,开始下一轮递归......

最终DFS结束,我们检查是否所有房间都是可以进入的即可。

代码:

cpp 复制代码
class Solution {
public:
    void dfs(vector<bool>&temp,vector<vector<int>>& rooms,vector<int> key){
        for(int k:key){ //遍历我们有的钥匙
            if(temp[k]) continue;   //如果我们能进入对应的房间,那么我们之前遍历过了,这边剪枝.
            temp[k]=true;   //如果之前不能进入,那么现在可以进了,那么做个标记
            dfs(temp,rooms,rooms[k]);   //再接着递归现在进入的房间里内含的钥匙
        }
    }
    bool canVisitAllRooms(vector<vector<int>>& rooms) {
        vector<bool>temp(rooms.size(),false);   //是否能进入对应房间
        temp[0]=true;   //首先我们是可以进入到第一个房间
        dfs(temp,rooms,rooms[0]);   //dfs,传入可以进的房间,以及每个房间内含钥匙情况,和我们已经有的钥匙
        for(bool t:temp){   //遍历能否进入房间的情况,如果都可以进就返回true.
            if(!t) return false;
        }
        return true;
    }
};
相关推荐
2401_831824961 天前
基于C++的区块链实现
开发语言·c++·算法
We་ct1 天前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
愣头不青1 天前
238.除了自身以外数组的乘积
数据结构·算法
汉克老师1 天前
GESP5级C++考试语法知识(六、链表(一)单链表)
c++·链表·单链表·快慢指针·进阶·gesp5级·gesp五级
人工智能AI酱1 天前
【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议
人工智能·python·算法·机器学习·ai·逻辑回归·正则化
WangLanguager1 天前
逻辑回归(Logistic Regression)的详细介绍及Python代码示例
python·算法·逻辑回归
m0_518019481 天前
C++与机器学习框架
开发语言·c++·算法
一段佳话^cyx1 天前
详解逻辑回归(Logistic Regression):原理、推导、实现与实战
大数据·算法·机器学习·逻辑回归
qq_417695051 天前
C++中的代理模式高级应用
开发语言·c++·算法
学嵌入式的小杨同学1 天前
STM32 进阶封神之路(十九):ADC 深度解析 —— 从模拟信号到数字转换(底层原理 + 寄存器配置)
c++·stm32·单片机·嵌入式硬件·mcu·架构·硬件架构