zoukankan      html  css  js  c++  java
  • 1462. 课程安排 IV

    你总共需要上 n 门课,课程编号依次为 0 到 n-1 。

    有的课会有直接的先修课程,比如如果想上课程 0 ,你必须先上课程 1 ,那么会以 [1,0] 数对的形式给出先修课程数对。

    给你课程总数 n 和一个直接先修课程数对列表 prerequisite 和一个查询对列表 queries 。

    对于每个查询对 queries[i] ,请判断 queries[i][0] 是否是 queries[i][1] 的先修课程。

    请返回一个布尔值列表,列表中每个元素依次分别对应 queries 每个查询对的判断结果。

    注意:如果课程 a 是课程 b 的先修课程且课程 b 是课程 c 的先修课程,那么课程 a 也是课程 c 的先修课程。

    示例 1:

    输入:n = 2, prerequisites = [[1,0]], queries = [[0,1],[1,0]]
    输出:[false,true]
    解释:课程 0 不是课程 1 的先修课程,但课程 1 是课程 0 的先修课程。
    

    示例 2:

    输入:n = 2, prerequisites = [], queries = [[1,0],[0,1]]
    输出:[false,false]
    解释:没有先修课程对,所以每门课程之间是独立的。
    

    示例 3:

    输入:n = 3, prerequisites = [[1,2],[1,0],[2,0]], queries = [[1,0],[1,2]]
    输出:[true,true]
    

    示例 4:

    输入:n = 3, prerequisites = [[1,0],[2,0]], queries = [[0,1],[2,0]]
    输出:[false,true]
    

    示例 5:

    输入:n = 5, prerequisites = [[0,1],[1,2],[2,3],[3,4]], queries = [[0,4],[4,0],[1,3],[3,0]]
    输出:[true,false,true,false]
    

    提示:

    • 2 <= n <= 100
    • 0 <= prerequisite.length <= (n * (n - 1) / 2)
    • 0 <= prerequisite[i][0], prerequisite[i][1] < n
    • prerequisite[i][0] != prerequisite[i][1]
    • 先修课程图中没有环。
    • 先修课程图中没有重复的边。
    • 1 <= queries.length <= 10^4
    • queries[i][0] != queries[i][1]
    class Solution {
    public:
        vector<bool> checkIfPrerequisite(int n, vector<vector<int>>& prerequisites, vector<vector<int>>& queries) {
            vector<vector<bool>>graph(n,vector<bool>(n,false));
            for(int i=0;i<prerequisites.size();i++){
                graph[prerequisites[i][0]][prerequisites[i][1]]=true;
                for(int j=0;j<n;j++){
                    if(graph[j][prerequisites[i][0]]==true)
                        graph[j][prerequisites[i][1]]=true;
                }
                for(int j=0;j<n;j++){
                    if(graph[prerequisites[i][1]][j]==true)
                        graph[prerequisites[i][0]][j]=true;
                }
            }
            vector<bool>res(queries.size(),false);
            for(int i=0;i<queries.size();i++){
                res[i]=graph[queries[i][0]][queries[i][1]];
            }
            return res;
        }
    };
    class Solution {
    public:
        vector<bool> checkIfPrerequisite(int n, vector<vector<int>>& prerequisites, vector<vector<int>>& queries) {
            vector<vector<bool>>graph(n,vector<bool>(n,false));
            for(int i=0;i<prerequisites.size();i++){
                graph[prerequisites[i][0]][prerequisites[i][1]]=true;
            }
    
            //floyd
            for(int i=0;i<n;i++){
                for(int j=0;j<n;j++){
                    for(int k=0;k<n;k++){
                        if(graph[j][i]&&graph[i][k])
                            graph[j][k]=true;
                    }
                }
            }
    
            vector<bool>res(queries.size(),false);
            for(int i=0;i<queries.size();i++){
                res[i]=graph[queries[i][0]][queries[i][1]];
            }
            return res;
        }
    };

  • 相关阅读:
    Vue-基础(四)
    Vue-基础(三)
    Vue-基础(一)
    Vue-基础(二)
    CSS-初始化模板2(common.css)
    CSS-初始化模板1(normalize.css)
    CSS预处理器-Less
    MySQL视窗函数row_number(), rank(), denser_rank()
    LeetCode第4题:寻找两个有序数组的中位数
    无重复字符的最长子串
  • 原文地址:https://www.cnblogs.com/xxxsans/p/14081257.html
Copyright © 2011-2022 走看看