Keys and Rooms

There areNrooms and you start in room0. Each room has a distinct number in0, 1, 2, ..., N-1, and each room may have some keys to access the next room.

Formally, each roomi has a list of keysrooms[i], and each keyrooms[i][j]is an integer in[0, 1, ..., N-1]whereN = rooms.length. A keyrooms[i][j] = v opens the room with numberv.

Initially, all the rooms start locked (except for room0).

You can walk back and forth between rooms freely.

Returntrue if and only if you can enter every room.

  1. 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:

Note:

分析

除了初始入栈visited也入0,后面是出栈时入visited

DFS

起始点开始,每个房间走下去

Last updated

Was this helpful?