Advertisement
ogv

Untitled

ogv
Sep 23rd, 2019
132
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 1.05 KB | None | 0 0
  1. // 39.33%
  2. class Solution {
  3.     public int[] findOrder(int numCourses, int[][] prerequisites) {
  4.         int[] dc = new int[numCourses];
  5.         ArrayList<ArrayList<Integer>> deps = new ArrayList<ArrayList<Integer>>();
  6.        
  7.         for (int i = 0; i < numCourses; i++) {
  8.             deps.add(new ArrayList<Integer>());
  9.         }
  10.        
  11.         for (int[] req: prerequisites) {
  12.             deps.get(req[1]).add(req[0]);
  13.             dc[req[0]] += 1;
  14.         }
  15.        
  16.        
  17.         int[] res = new int[numCourses];
  18.         int rPos = 0;
  19.        
  20.         while (rPos < numCourses){
  21.             boolean f = false;
  22.            
  23.             for (int node = 0; node < numCourses; node++) {
  24.                 if (dc[node] == 0) {
  25.                     dc[node] = -1;
  26.                     for (int d: deps.get(node)) dc[d] -= 1;
  27.            
  28.                     res[rPos++] = node;
  29.                     f = true;
  30.                 }
  31.             }
  32.            
  33.             if (!f) return new int[0];
  34.         }
  35.        
  36.         return res;
  37.     }      
  38. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement