-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCourseSchedule.java
41 lines (37 loc) · 1.16 KB
/
CourseSchedule.java
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
class Solution {
public boolean canFinish(int numCourses, int[][] prerequisites) {
if(prerequisites.length==0)
return true;
int[] out = new int[numCourses];
List<List<Integer>> li = new LinkedList<>();
for(int i=0;i<numCourses;i++)
li.add(new LinkedList<Integer>());
for( int[] a : prerequisites){
li.get(a[1]).add(a[0]);
out[a[0]]++;
}
// for(int i=0;i<li.size();i++)
// System.out.println(i+":=>"+li.get(i));
int index=-1;
for(int i = 0;i<numCourses;i++){
index = -1;
for(int j=0;j<numCourses;j++){
if(out[j]==0){
index=j;
break;
}
}
// System.out.println(index);
if(index==-1)
return false;
else{
for(int k = 0;k<li.get(index).size();k++){
if(out[li.get(index).get(k)]>0)
out[li.get(index).get(k)]--;
}
out[index]=-1;
}
}
return true;
}
}