Class Solution
-
- All Implemented Interfaces:
public final class Solution1462 - Course Schedule IV.
Medium
There are a total of
numCoursescourses you have to take, labeled from0tonumCourses - 1. You are given an arrayprerequisiteswhere <code>prerequisitesi = a<sub>i</sub>, b<sub>i</sub></code> indicates that you must take course <code>a<sub>i</sub></code> first if you want to take course <code>b<sub>i</sub></code>.For example, the pair
[0, 1]indicates that you have to take course0before you can take course1.
Prerequisites can also be indirect. If course
ais a prerequisite of courseb, and coursebis a prerequisite of coursec, then courseais a prerequisite of coursec.You are also given an array
querieswhere <code>queriesj = u<sub>j</sub>, v<sub>j</sub></code>. For the <code>j<sup>th</sup></code> query, you should answer whether course <code>u<sub>j</sub></code> is a prerequisite of course <code>v<sub>j</sub></code> or not.Return a boolean array
answer, whereanswer[j]is the answer to the <code>j<sup>th</sup></code> query.Example 1:
Input: numCourses = 2, prerequisites = [1,0], queries = [0,1,1,0]
Output: false,true
Explanation: The pair 1, 0 indicates that you have to take course 1 before you can take course 0. Course 0 is not a prerequisite of course 1, but the opposite is true.
Example 2:
Input: numCourses = 2, prerequisites = [], queries = [1,0,0,1]
Output: false,false
Explanation: There are no prerequisites, and each course is independent.
Example 3:
Input: numCourses = 3, prerequisites = [1,2,1,0,2,0], queries = [1,0,1,2]
Output: true,true
Constraints:
2 <= numCourses <= 1000 <= prerequisites.length <= (numCourses * (numCourses - 1) / 2)prerequisites[i].length == 2<code>0 <= a<sub>i</sub>, b<sub>i</sub><= n - 1</code>
<code>a<sub>i</sub> != b<sub>i</sub></code>
All the pairs <code>a<sub>i</sub>, b<sub>i</sub></code> are unique.
The prerequisites graph has no cycles.
<code>1 <= queries.length <= 10<sup>4</sup></code>
<code>0 <= u<sub>i</sub>, v<sub>i</sub><= n - 1</code>
<code>u<sub>i</sub> != v<sub>i</sub></code>