LeetCode 841 钥匙和房间 JavaScript

首先看到这个题目,应该意识到这是一个有向图,然后通过深度优先搜索或者广度优先搜索来解决这道题 。

关于深度优先搜索和广度优先搜索可以看我的这一篇文章,理解一下它们的思想,或者你就有思路做这道题了。

深度优先搜索(dfs)和广度优先搜索(bfs)_猫弦920的博客-CSDN博客

下面是我用广度优先搜索解决的代码 语言是JavaScript

var canVisitAllRooms = function (rooms) {
            var keys = [0];
            var length = 0;
            while (length <= keys.length) {
                let key = rooms[keys[length]];
                if (typeof key === 'object') {
                    for (let i = 0; i < key.length; i++) {
                        if (keys.includes(key[i])) {
                            continue;
                        } else {
                            keys.push(key[i]);
                        }
                    }
                } else if (rooms.includes(key)) {
                    if (!keys.includes(key)) {
                        keys.push(key);
                    }
                }
                length++;
            }
            if (keys.length == rooms.length) {
                return true;
            } else {
                return false;
            }
        };

关于深度优先搜索,大家也可以试试,或者有需要的话,之后再补充一下深度优先搜索解这道题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值