★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公众号:山青咏芝(shanqingyongzhi)
➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:http://www.javashuo.com/article/p-olocecra-ku.html
➤若是连接不是山青咏芝的博客园地址,则多是爬取做者的文章。
➤原文已修改更新!强烈建议点击原文地址阅读!支持做者!支持原创!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
There are N
courses, labelled from 1 to N
.git
We are given relations[i] = [X, Y]
, representing a prerequisite relationship between course X
and course Y
: course X
has to be studied before course Y
.github
In one semester you can study any number of courses as long as you have studied all the prerequisites for the course you are studying.微信
Return the minimum number of semesters needed to study all courses. If there is no way to study all the courses, return -1
. 学习
Example 1:ui
Input: N = 3, relations = [[1,3],[2,3]] Output: 2 Explanation: In the first semester, courses 1 and 2 are studied. In the second semester, course 3 is studied.
Example 2:spa
Input: N = 3, relations = [[1,2],[2,3],[3,1]] Output: -1 Explanation: No course can be studied because they depend on each other.
Note:code
1 <= N <= 5000
1 <= relations.length <= 5000
relations[i][0] != relations[i][1]
有n个课程,从1到n标记。咱们获得关系[i]=[x,y],表示课程x和课程y之间的先决条件关系:课程x必须在课程y以前学习。在一个学期内,你能够学习任意数量的课程,只要你已经学习了你所学课程的全部先决条件。返回学习全部课程所需的最少学期数。若是没有办法学习全部课程,返回-1。htm
例1:blog
输入:n=3,relations=[[1,3],[2,3]]
输出:2
说明:
第一学期,学习课程1和2。第二学期,学习第三门课程。
例2:
输入:n=3,relations=[[1,2],[2,3],[3,1]]
输出:-1
说明:
任何课程都不能学习,由于它们相互依赖。
提示:
1 <= N <= 5000
1 <= relations.length <= 5000
relations[i][0] != relations[i][1]