forked from jeantimex/javascript-problems-and-solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkeys-and-rooms.js
75 lines (68 loc) · 1.81 KB
/
keys-and-rooms.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/**
* Keys and Rooms
*
* There are N rooms and you start in room 0. Each room has a distinct number in 0, 1, 2, ..., N-1,
* and each room may have some keys to access the next room.
*
* Formally, each room i has a list of keys rooms[i], and each key rooms[i][j] is an integer in [0, 1, ..., N-1]
* where N = rooms.length. A key rooms[i][j] = v opens the room with number v.
*
* Initially, all the rooms start locked (except for room 0).
*
* You can walk back and forth between rooms freely.
*
* Return true if and only if you can enter every room.
*
* Example 1:
*
* Input: [[1],[2],[3],[]]
* Output: true
*
* Explanation:
* We start in room 0, and pick up key 1.
* We then go to room 1, and pick up key 2.
* We then go to room 2, and pick up key 3.
* We then go to room 3. Since we were able to go to every room, we return true.
*
* Example 2:
*
* Input: [[1,3],[3,0,1],[2],[0]]
* Output: false
*
* Explanation: We can't enter the room with number 2.
*
* Note:
*
* 1 <= rooms.length <= 1000
* 0 <= rooms[i].length <= 1000
* The number of keys in all rooms combined is at most 3000.
*/
/**
* @param {number[][]} rooms
* @return {boolean}
*/
const canVisitAllRooms = rooms => {
const roomsToVisit = new Set();
for (let i = 0; i < rooms.length; i++) {
roomsToVisit.add(i);
}
return helper(rooms, 0, roomsToVisit);
};
const helper = (rooms, index, roomsToVisit) => {
// mark the room as visited
roomsToVisit.delete(index);
if (roomsToVisit.size === 0) {
return true;
}
for (let roomIndex of rooms[index]) {
if (roomsToVisit.has(roomIndex)) {
if (helper(rooms, roomIndex, roomsToVisit)) {
return true;
}
}
}
// unmark current room index as visited if we can not walk back
//roomsToVisit.add(index);
return false;
};
export { canVisitAllRooms };