Leetcode 53.课程表-原题链接
题目内容
你这个学期必须选修 numCourses 门课程,记为 0到 numCourses−1 。
在选修某些课程之前需要一些先修课程。 先修课程按数组 prerequisites 给出,其中 prerequisites[i]=[ai,bi] ,表示如果要学习课程 ai则 必须 先学习课程 bi 。
- 例如,先修课程对 [0,1] 表示:想要学习课程 0,你需要先完成课程 1 。
请你判断是否可能完成所有课程的学习?如果可以,返回 true ;否则,返回 false 。
输入描述
- 第一行输入一个整数 numCourses,表示课程总数。
- 第二行输入一个整数 m,表示先修课程对的数量。
- 接下来 m 行,每行输入两个整数 aibi,表示课程 ai 需要先修 bi。
输出描述
如果可以完成所有课程的学习,输出 true,否则输出 false。
样例1
输入
2
1
1 0
输出
true
说明
总共有 2门课程。学习课程 1 之前,你需要完成课程0 。这是可能的。
样例2
输入
2
2
1 0
0 1
输出
false
说明
总共有 2 门课程。学习课程 1之前,你需要先完成课程0;并且学习课程0之前,你还应先完成课程 1 。这是不可能的。
提示
- 1<=numCourses<=2000
- 0<=prerequisites.length<=5000
- prerequisites[i].length==2
- 0<=ai,bi<numCourses
- prerequisites[i]中的所有课程对互不相同