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

题解:

相关推荐
Remember_9931 天前
【数据结构】深入理解Map和Set:从搜索树到哈希表的完整解析
java·开发语言·数据结构·算法·leetcode·哈希算法·散列表
TTGGGFF1 天前
控制系统建模仿真(二):掌握控制系统设计的 MAD 流程与 MATLAB 基础运算
开发语言·数据结构·matlab
金融小师妹1 天前
基于AI多模态分析的日本黄金储备60%跃升研究:外汇结构重构与资产价格联动机制解构
大数据·数据结构·人工智能·深度学习
重生之后端学习1 天前
25. K 个一组翻转链表
java·数据结构·算法·leetcode·职场和发展
虹科网络安全1 天前
艾体宝洞察 | 不止步于缓存 - Redis 多数据结构平台的演进与实践
数据结构·redis·缓存
ajole1 天前
C++学习笔记——stack和queue
开发语言·数据结构·c++·笔记·学习·stl·学习方法
ValhallaCoder1 天前
Day51-图论
数据结构·python·算法·图论
苦藤新鸡1 天前
24.判断回文链表
数据结构·链表
进击的荆棘1 天前
优选算法——双指针
数据结构·算法
努力努力再努力wz1 天前
【Linux网络系列】:JSON+HTTP,用C++手搓一个web计算器服务器!
java·linux·运维·服务器·c语言·数据结构·c++