Reorder Routes to Make All Paths Lead to the City Zero
ID:1466
Input: n = 6, connections = [[0,1],[1,3],[2,3],[4,0],[4,5]]
Output: 3
Explanation: Change the direction of edges show in red such that each node can reach the node 0 (capital).Idea
Code
public int minReorder(int n, int[][] connections) {
Map<Integer, List<Integer>> undirected = new HashMap<>();
Map<Integer, List<Integer>> directed = new HashMap<>();
for(int[] c: connections){
int from = c[0];
int to = c[1];
List<Integer> nei = directed.getOrDefault(from, new ArrayList<>());
nei.add(to);
directed.put(from, nei);
List<Integer> listFrom = undirected.getOrDefault(from, new ArrayList<>());
listFrom.add(to);
undirected.put(from, listFrom);
List<Integer> listTo = undirected.getOrDefault(to, new ArrayList<>());
listTo.add(from);
undirected.put(to, listTo);
}
Queue<Integer> q = new LinkedList<>();
Set<Integer> seen = new HashSet<>();
seen.add(0);
q.offer(0);
int rev = 0;
while(!q.isEmpty()){
int curr = q.poll();
for(int nei: undirected.get(curr)){
if(!seen.contains(nei)){
if(directed.get(curr) !=null && directed.get(curr).contains(nei)){
rev++;
}
q.offer(nei);
seen.add(nei);
}
}
}
return rev;
}Last updated
