-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path841.keys-and-rooms.cpp
89 lines (88 loc) · 1.95 KB
/
841.keys-and-rooms.cpp
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/*
* @lc app=leetcode id=841 lang=cpp
*
* [841] Keys and Rooms
*
* https://leetcode.com/problems/keys-and-rooms/description/
*
* algorithms
* Medium (59.17%)
* Total Accepted: 26.6K
* Total Submissions: 44.9K
* Testcase Example: '[[1],[2],[3],[]]'
*
* 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.
*
*
*/
#include <vector>
#include <queue>
#include <set>
using namespace std;
class Solution
{
public:
bool canVisitAllRooms(vector<vector<int>> &rooms)
{
int target = rooms.size();
queue<int> q;
set<int> v;
q.push(0);
while (!q.empty())
{
int key = q.front();
q.pop();
if (v.find(key) != v.end())
continue;
v.insert(key);
for (auto k : rooms[key])
{
q.push(k);
}
}
return v.size() == target;
}
};