C++ | Leetcode C++题解之第207题课程表

题目:

题解:

cpp 复制代码
class Solution {
private:
    vector<vector<int>> edges;
    vector<int> indeg;

public:
    bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {
        edges.resize(numCourses);
        indeg.resize(numCourses);
        for (const auto& info: prerequisites) {
            edges[info[1]].push_back(info[0]);
            ++indeg[info[0]];
        }

        queue<int> q;
        for (int i = 0; i < numCourses; ++i) {
            if (indeg[i] == 0) {
                q.push(i);
            }
        }

        int visited = 0;
        while (!q.empty()) {
            ++visited;
            int u = q.front();
            q.pop();
            for (int v: edges[u]) {
                --indeg[v];
                if (indeg[v] == 0) {
                    q.push(v);
                }
            }
        }

        return visited == numCourses;
    }
};
相关推荐
緈福的街口6 小时前
【leetcode】347. 前k个高频元素
算法·leetcode·职场和发展
南郁7 小时前
007-nlohmann/json 项目应用-C++开源库108杰
c++·开源·json·nlohmann·现代c++·d2school·108杰
菠萝018 小时前
共识算法Raft系列(1)——什么是Raft?
c++·后端·算法·区块链·共识算法
海棠蚀omo8 小时前
C++笔记-C++11(一)
开发语言·c++·笔记
凌佚9 小时前
rknn优化教程(一)
c++·目标检测·性能优化
小河豚oO11 小时前
LeetCode刷题---贪心算法---944
算法·leetcode·贪心算法
Lenyiin11 小时前
《 C++ 点滴漫谈: 四十 》文本的艺术:C++ 正则表达式的高效应用之道
c++·正则表达式·lenyiin
Once_day12 小时前
代码训练LeetCode(23)随机访问元素
算法·leetcode
小河豚oO12 小时前
LeetCode 热题 100 - 哈希 - 128
算法·leetcode·哈希算法
客卿12312 小时前
力扣100题之128. 最长连续序列
算法·leetcode·哈希算法