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

题解:

相关推荐
轮到我狗叫了1 小时前
力扣智慧思想小题,目录力扣.跳跃游戏(思想很重要)力扣.跳跃游戏II(还是思想)力扣.分发糖果力扣151.反转字符串中的单词力扣.轮转数组
数据结构·算法·leetcode
10000hours1 小时前
【SGL】Scatter-Gather List内存传输技术
linux·数据结构·网络协议·list·存储·sgl
海盐泡泡龟2 小时前
ES6新增Set、Map两种数据结构、WeakMap、WeakSet举例说明详细。(含DeepSeek讲解)
前端·数据结构·es6
少了一只鹅3 小时前
深入理解指针(3)
c语言·数据结构·算法
似水এ᭄往昔3 小时前
【数据结构】——双向链表
c语言·数据结构·c++·链表
有一个好名字3 小时前
力扣:轮转数组
数据结构·算法·leetcode
fpcc3 小时前
跟我学C++中级篇——STL容器的查找对比
数据结构·c++
小兔子2534 小时前
嵌入式培训之C语言学习完(十七)结构体、共用体、枚举、typedef关键字与位运算
数据结构
菜鸟破茧计划4 小时前
线段树:数据结构中的超级英雄
数据结构·c++·算法
找不到、了5 小时前
JDK8 HashMap红黑树退化为链表的机制解析
java·数据结构·链表