2023-12-09 18:42:21 +08:00
|
|
|
|
<p>给你一个整数 <code>n</code> 表示某所大学里课程的数目,编号为 <code>1</code> 到 <code>n</code> ,数组 <code>relations</code> 中, <code>relations[i] = [x<sub>i</sub>, y<sub>i</sub>]</code> 表示一个先修课的关系,也就是课程 <code>x<sub>i</sub></code> 必须在课程 <code>y<sub>i</sub></code><sub> </sub>之前上。同时你还有一个整数 <code>k</code> 。</p>
|
2022-03-27 20:37:52 +08:00
|
|
|
|
|
|
|
|
|
<p>在一个学期中,你 <strong>最多</strong> 可以同时上 <code>k</code> 门课,前提是这些课的先修课在之前的学期里已经上过了。</p>
|
|
|
|
|
|
|
|
|
|
<p>请你返回上完所有课最少需要多少个学期。题目保证一定存在一种上完所有课的方式。</p>
|
|
|
|
|
|
|
|
|
|
<p> </p>
|
|
|
|
|
|
|
|
|
|
<p><strong>示例 1:</strong></p>
|
|
|
|
|
|
2023-12-09 18:42:21 +08:00
|
|
|
|
<p><strong><img alt="" src="https://assets.leetcode-cn.com/aliyun-lc-upload/uploads/2020/06/27/leetcode_parallel_courses_1.png" style="height: 164px; width: 300px;" /></strong></p>
|
2022-03-27 20:37:52 +08:00
|
|
|
|
|
2023-12-09 18:42:21 +08:00
|
|
|
|
<pre>
|
|
|
|
|
<strong>输入:</strong>n = 4, relations = [[2,1],[3,1],[1,4]], k = 2
|
2022-03-27 20:37:52 +08:00
|
|
|
|
<strong>输出:</strong>3
|
|
|
|
|
<strong>解释:</strong>上图展示了题目输入的图。在第一个学期中,我们可以上课程 2 和课程 3 。然后第二个学期上课程 1 ,第三个学期上课程 4 。
|
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
|
|
<p><strong>示例 2:</strong></p>
|
|
|
|
|
|
2023-12-09 18:42:21 +08:00
|
|
|
|
<p><strong><img alt="" src="https://assets.leetcode-cn.com/aliyun-lc-upload/uploads/2020/06/27/leetcode_parallel_courses_2.png" style="height: 234px; width: 300px;" /></strong></p>
|
2022-03-27 20:37:52 +08:00
|
|
|
|
|
2023-12-09 18:42:21 +08:00
|
|
|
|
<pre>
|
|
|
|
|
<strong>输入:</strong>n = 5, relations = [[2,1],[3,1],[4,1],[1,5]], k = 2
|
2022-03-27 20:37:52 +08:00
|
|
|
|
<strong>输出:</strong>4
|
|
|
|
|
<strong>解释:</strong>上图展示了题目输入的图。一个最优方案是:第一学期上课程 2 和 3,第二学期上课程 4 ,第三学期上课程 1 ,第四学期上课程 5 。
|
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
|
|
<p><strong>示例 3:</strong></p>
|
|
|
|
|
|
2023-12-09 18:42:21 +08:00
|
|
|
|
<pre>
|
|
|
|
|
<strong>输入:</strong>n = 11, relations = [], k = 2
|
2022-03-27 20:37:52 +08:00
|
|
|
|
<strong>输出:</strong>6
|
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
|
|
<p> </p>
|
|
|
|
|
|
|
|
|
|
<p><strong>提示:</strong></p>
|
|
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
|
<li><code>1 <= n <= 15</code></li>
|
|
|
|
|
<li><code>1 <= k <= n</code></li>
|
2023-12-09 18:42:21 +08:00
|
|
|
|
<li><code>0 <= relations.length <= n * (n-1) / 2</code></li>
|
|
|
|
|
<li><code>relations[i].length == 2</code></li>
|
2022-03-27 20:37:52 +08:00
|
|
|
|
<li><code>1 <= x<sub>i</sub>, y<sub>i</sub> <= n</code></li>
|
|
|
|
|
<li><code>x<sub>i</sub> != y<sub>i</sub></code></li>
|
2023-12-09 18:42:21 +08:00
|
|
|
|
<li>所有先修关系都是不同的,也就是说 <code>relations[i] != relations[j]</code> 。</li>
|
2022-03-27 20:37:52 +08:00
|
|
|
|
<li>题目输入的图是个有向无环图。</li>
|
|
|
|
|
</ul>
|