-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path210.课程表-ii.go
49 lines (45 loc) · 1.05 KB
/
210.课程表-ii.go
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
42
43
44
45
46
47
48
/*
* @lc app=leetcode.cn id=210 lang=golang
*
* [210] 课程表 II
*/
// @lc code=start
func findOrder(numCourses int, prerequisites [][]int) []int {
// 构造有向图, 进行拓扑排序, 使用深度优先算法
var (
// 有向边(a, b), 如果b依赖a, 则 a -> b
edges = make([][]int, numCourses) // 下标为课程编号, 存储其指向的课程, 必须有size
// 顶点的入度
indegree = make([]int, numCourses) // 必须有size
result = make([]int, 0)
)
// 构造有向边和入度
for _, p := range prerequisites {
edges[p[1]] = append(edges[p[1]], p[0])
indegree[p[0]]++
}
q := []int{}
// 将入度为0的节点放入队列
for i, v := range indegree {
if v == 0 {
q = append(q, i)
}
}
for len(q) > 0 {
// 每次删除队列头部元素, 并将其指向的顶点的入度减一
c := q[0]
q = q[1:]
result = append(result, c)
for _, v := range edges[c] {
indegree[v]--
if indegree[v] == 0 {
q = append(q, v)
}
}
}
if len(result) != numCourses {
return []int{}
}
return result
}
// @lc code=end