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;
    }
};

题解:

相关推荐
Pluchon2 小时前
硅基计划6.0 柒 JavaEE 浅谈JVM&GC垃圾回收
java·jvm·数据结构·java-ee·gc
不穿格子的程序员3 小时前
从零开始刷算法——二分-搜索旋转排序数组
数据结构·算法
sin_hielo4 小时前
leetcode 2536
数据结构·算法·leetcode
what_20184 小时前
list集合使用
数据结构·算法·list
im_AMBER6 小时前
数据结构 11 图
数据结构·笔记·学习·图论
xiaoye-duck7 小时前
数据结构之二叉树-链式结构(上)
数据结构
Doro再努力7 小时前
2025_11_14洛谷【入门1】数据结构刷题小结
前端·数据结构·算法
cs麦子7 小时前
C语言--详解--指针--下
c语言·数据结构·算法
flashlight_hi7 小时前
LeetCode 分类刷题:3217. 从链表中移除在数组中存在的节点
javascript·数据结构·leetcode·链表
oioihoii8 小时前
C++中有双向映射数据结构吗?Key和Value能否双向查找?
数据结构·c++·算法