g0801_0900.s0802_find_eventual_safe_states.Solution Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-java Show documentation
Show all versions of leetcode-in-java Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
package g0801_0900.s0802_find_eventual_safe_states;
// #Medium #Depth_First_Search #Breadth_First_Search #Graph #Topological_Sort
import java.util.ArrayList;
import java.util.List;
public class Solution {
public List eventualSafeNodes(int[][] graph) {
List res = new ArrayList<>();
int[] vis = new int[graph.length];
for (int i = 0; i < graph.length; i++) {
if (dfs(graph, i, vis)) {
res.add(i);
}
}
return res;
}
private boolean dfs(int[][] graph, int src, int[] vis) {
if (vis[src] != 0) {
return vis[src] == 2;
}
vis[src] = 1;
for (int x : graph[src]) {
if (!dfs(graph, x, vis)) {
return false;
}
}
vis[src] = 2;
return true;
}
}