Leetcode207. 课程表(HOT100)

链接

题解:先统计入度为0的点,如果一个节点入度为0,说明没有课程指向它,那么你就可以学习它了。反之说明还有先修课。

注意:图存在拓扑排序等价于图不存在环。其实可以想出:如果是一个环,那么就没有突破点。

代码:

cpp 复制代码
class Solution {
public:
    bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {
        int n = numCourses;//可以直接改变形参为n,方便代码书写
        vector<vector<int>> g(n);
        vector<int> d(n);
        for(const auto&e:prerequisites){
            int b = e[0],a = e[1];
            g[a].push_back(b);
            d[b]++;
        }
        queue<int> q;
        for(int i = 0;i<n;i++){
            if(d[i]==0){
                q.push(i);
            }
        }
        
        int cnt = 0;
        while(q.size()){
            int a = q.front();
            q.pop();
            cnt++;
            for(const auto&e:g[a]){
                if(--d[e]==0){
                    q.push(e);
                }
            }

        }
        return cnt==n;
    }
};

题解:

相关推荐
流年如夢9 小时前
排序算法详解
数据结构·算法·排序算法
z2005093010 小时前
今日算法(二叉树)
数据结构·c++·算法
故事和你9110 小时前
洛谷-【图论2-2】最短路1
开发语言·数据结构·c++·算法·动态规划·图论
Simple-Soft11 小时前
指针的高级应用与技巧 - C语言的灵魂
c语言·数据结构·算法
Controller-Inversion11 小时前
23. 合并 K 个升序链表
数据结构·链表
Mr_pyx11 小时前
面试题记录
jvm·数据结构·算法·spring·mybatis
努力努力再努力wz11 小时前
【C++高阶数据结构系列】:时间轮定时器详解:原理分析与代码实现,带你从零手撕时间轮!(附时间轮的实现源码)
c语言·开发语言·数据结构·c++·qt·算法·ui
iiiiyu12 小时前
⾯向对象和集合编程题
java·大数据·开发语言·数据结构·编程语言
YuanDaima204812 小时前
贪心算法基础原理与题目说明
数据结构·人工智能·python·算法·贪心算法·手撕代码