Skip to content

Commit f2c84f6

Browse files
committed
Sync LeetCode submission Runtime - 3 ms (89.27%), Memory - 18.8 MB (77.79%)
1 parent 0ef84c5 commit f2c84f6

File tree

2 files changed

+71
-0
lines changed

2 files changed

+71
-0
lines changed

0207-course-schedule/README.md

Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
<p>There are a total of <code>numCourses</code> courses you have to take, labeled from <code>0</code> to <code>numCourses - 1</code>. You are given an array <code>prerequisites</code> where <code>prerequisites[i] = [a<sub>i</sub>, b<sub>i</sub>]</code> indicates that you <strong>must</strong> take course <code>b<sub>i</sub></code> first if you want to take course <code>a<sub>i</sub></code>.</p>
2+
3+
<ul>
4+
<li>For example, the pair <code>[0, 1]</code>, indicates that to take course <code>0</code> you have to first take course <code>1</code>.</li>
5+
</ul>
6+
7+
<p>Return <code>true</code> if you can finish all courses. Otherwise, return <code>false</code>.</p>
8+
9+
<p>&nbsp;</p>
10+
<p><strong class="example">Example 1:</strong></p>
11+
12+
<pre>
13+
<strong>Input:</strong> numCourses = 2, prerequisites = [[1,0]]
14+
<strong>Output:</strong> true
15+
<strong>Explanation:</strong> There are a total of 2 courses to take.
16+
To take course 1 you should have finished course 0. So it is possible.
17+
</pre>
18+
19+
<p><strong class="example">Example 2:</strong></p>
20+
21+
<pre>
22+
<strong>Input:</strong> numCourses = 2, prerequisites = [[1,0],[0,1]]
23+
<strong>Output:</strong> false
24+
<strong>Explanation:</strong> There are a total of 2 courses to take.
25+
To take course 1 you should have finished course 0, and to take course 0 you should also have finished course 1. So it is impossible.
26+
</pre>
27+
28+
<p>&nbsp;</p>
29+
<p><strong>Constraints:</strong></p>
30+
31+
<ul>
32+
<li><code>1 &lt;= numCourses &lt;= 2000</code></li>
33+
<li><code>0 &lt;= prerequisites.length &lt;= 5000</code></li>
34+
<li><code>prerequisites[i].length == 2</code></li>
35+
<li><code>0 &lt;= a<sub>i</sub>, b<sub>i</sub> &lt; numCourses</code></li>
36+
<li>All the pairs prerequisites[i] are <strong>unique</strong>.</li>
37+
</ul>

0207-course-schedule/solution.py

Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
# Approach 1: Topological Sort Using Kahn's Algorithm
2+
3+
# n = no. of coures, m = len(prerequistes)
4+
# Time: O(m + n)
5+
# Space: O(m + n)
6+
7+
from collections import deque
8+
9+
class Solution:
10+
def canFinish(self, numCourses: int, prerequisites: List[List[int]]) -> bool:
11+
indegree = [0] * numCourses
12+
adj = [[] for _ in range(numCourses)]
13+
14+
for prereq in prerequisites:
15+
adj[prereq[1]].append(prereq[0])
16+
indegree[prereq[0]] += 1
17+
18+
queue = deque()
19+
for i in range(numCourses):
20+
if indegree[i] == 0:
21+
queue.append(i)
22+
23+
nodesVisited = 0
24+
while queue:
25+
node = queue.popleft()
26+
nodesVisited += 1
27+
28+
for neighbor in adj[node]:
29+
indegree[neighbor] -= 1
30+
if indegree[neighbor] == 0:
31+
queue.append(neighbor)
32+
33+
return nodesVisited == numCourses
34+

0 commit comments

Comments
 (0)