图论|841钥匙和房间

题目: 有 n 个房间,房间按从 0 到 n - 1 编号。最初,除 0 号房间外的其余所有房间都被锁住。你的目标是进入所有的房间。然而,你不能在没有获得钥匙的时候进入锁住的房间。当你进入一个房间,你可能会在里面找到一套不同的钥匙,每把钥匙上都有对应的房间号,即表示钥匙可以打开的房间。你可以拿上所有钥匙去解锁其他房间。给你一个数组 rooms 其中 rooms[i] 是你进入 i 号房间可以获得的钥匙集合。如果能进入 所有 房间返回 true,否则返回 false。
题目链接: 841. 钥匙和房间
解题思路

java 复制代码
class Solution {
    public boolean canVisitAllRooms(List<List<Integer>> rooms) {
        //可以遍历所有房间指 从起点开始所有的点都可达
        //可以用栈解决
        //栈存放钥匙
        //hashset存放已被解锁的房间
        Stack<Integer> key=new Stack<Integer>();
        HashSet<Integer> room=new HashSet<Integer>();
        key.push(0);
        while(!key.isEmpty()){
            int now=key.pop();
            room.add(now);
            List<Integer> keys=rooms.get(now);
            for(int i=0;i<keys.size();i++){
                if(!room.contains(keys.get(i))){
                    key.push(keys.get(i));
                }
            }
        }
        if(room.size()==rooms.size()){
            return true;
        }else{
            return false;
        }
    }
}
相关推荐
Aurora_th5 小时前
树与图的深度优先遍历(dfs的图论中的应用)
c++·算法·深度优先·图论·dfs·树的直径
夏天天天天天天天#10 小时前
求Huffman树及其matlab程序详解
算法·matlab·图论
浅念同学13 小时前
算法.图论-建图/拓扑排序及其拓展
算法·图论
Greyplayground16 小时前
【算法基础实验】图论-BellmanFord最短路径
算法·图论·最短路径
逝去的秋风17 小时前
【代码随想录训练营第42期 Day61打卡 - 图论Part11 - Floyd 算法与A * 算法
算法·图论·floyd 算法·a -star算法
浅念同学18 小时前
算法.图论-并查集上
java·算法·图论
蠢蠢的打码1 天前
8584 循环队列的基本操作
数据结构·c++·算法·链表·图论
逝去的秋风4 天前
【代码随想录训练营第42期 Day57打卡 - 图论Part7 - Prim算法与Kruskal算法
算法·图论·prim算法
热爱编程的OP4 天前
图论篇--代码随想录算法训练营第六十一天打卡| Floyd 算法,A*算法
数据结构·c++·学习·算法·图论
Aurora_th4 天前
图论三元环(并查集的高级应用)
c++·算法·图论·并查集·观察力·三元环