Course Schedule
Problem
https://leetcode.com/problems/course-schedule/
There are a total of numCourses courses you have to take, labeled
from 0 to numCourses - 1. You are given an array
prerequisites where
prerequisites[i] = [a:sub:`i`, b:sub:`i`]
indicates that you must take course b:sub:`i` first if you
want to take course a:sub:`i`.
For example, the pair
[0, 1], indicates that to take course0you have to first take course1.
Return true if you can finish all courses. Otherwise, return
false.
Example 1:
Input: numCourses = 2, prerequisites = [[1,0]]
Output: true
Explanation: There are a total of 2 courses to take.
To take course 1 you should have finished course 0. So it is possible.
Example 2:
Input: numCourses = 2, prerequisites = [[1,0],[0,1]]
Output: false
Explanation: There are a total of 2 courses to take.
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.
Constraints:
1 <= numCourses <= 20000 <= prerequisites.length <= 5000prerequisites[i].length == 20 <= a:sub:`i`, b:sub:`i`< numCoursesAll the pairs prerequisites[i] are unique.
Pattern
Depth-First Search, Breadth-First Search, Graph Theory, Topological Sort
Approaches
Code
from collections import defaultdict, deque
def canFinish(numCourses: int, prerequisites: list[list[int]]) -> bool:
graph = defaultdict(list)
in_degrees = defaultdict(int)
for [a, b] in prerequisites:
graph[b].append(a)
graph[a]
in_degrees[a] += 1
in_degrees[b]
queue = deque()
for node, in_degree in in_degrees.items():
if in_degree == 0:
queue.append(node)
courses = set()
while queue:
node = queue.popleft()
courses.add(node)
for neighbor in graph[node]:
in_degrees[neighbor] -= 1
if in_degrees[neighbor] == 0:
queue.append(neighbor)
if len(courses) == len(graph):
return True
else:
return False
Test
>>> from course_schedule__topological_sort import canFinish
>>> canFinish(2, [[1, 0]])
True
>>> canFinish(2, [[1, 0], [0, 1]])
False
- course_schedule__topological_sort.canFinish(numCourses: int, prerequisites: list[list[int]]) bool