【LeetCode热题100】【图论】课程表

题目链接:207. 课程表 - 力扣(LeetCode)

先修课程,判断课程能不能修完,这是一个判断拓扑有序的问题,看看会不会成环

先建立有向图,记录每个顶点的入度,把入度为0的入队列

入度为0的说明没有先修课程,取出来修,并将相连的节点的入度减一,说明先修课程已经修了一个了,再判断有没有新的课程可以修的入队

最后判断修了的课程和要修的课程数目是否相等

class Solution {
public:
    bool canFinish(int numCourses, vector<vector<int> > &prerequisites) {
        vector<vector<int> > map(numCourses, vector<int>(numCourses));
        vector<int> inDegree(numCourses);
        for (auto must: prerequisites) {
            int from = must[1], to = must[0];
            ++inDegree[to];
            map[from][to] = 1;
        }
        queue<int> learned;
        for (int i = 0; i < numCourses; ++i)
            if (inDegree[i] == 0)
                learned.emplace(i);
        int pass = 0;
        while (!learned.empty()) {
            int passed = learned.front();
            learned.pop();
            pass++;
            for (int i = 0; i < numCourses; ++i) {
                if (map[passed][i]) {
                    --inDegree[i];
                    if (inDegree[i] == 0)
                        learned.emplace(i);
                }
            }
        }
        if (pass == numCourses)
            return true;
        return false;
    }
};

相关推荐

  1. LeetCode100】【课程表

    2024-04-23 09:56:01       40 阅读
  2. LeetCode 100 专题解析

    2024-04-23 09:56:01       16 阅读
  3. LeetCode100】【】岛屿数量

    2024-04-23 09:56:01       12 阅读
  4. LeetCode100】【】实现 Trie (前缀树)

    2024-04-23 09:56:01       10 阅读
  5. LeetCode100】【】腐烂的橘子

    2024-04-23 09:56:01       12 阅读
  6. LeetCode-100:207. 课程表

    2024-04-23 09:56:01       21 阅读
  7. Leetcode100

    2024-04-23 09:56:01       35 阅读
  8. LeetCode100

    2024-04-23 09:56:01       9 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-23 09:56:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-23 09:56:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-23 09:56:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-23 09:56:01       20 阅读

热门阅读

  1. Linux bond0 配置方法

    2024-04-23 09:56:01       14 阅读
  2. 【C++提高】算法

    2024-04-23 09:56:01       12 阅读
  3. 7-17 KMP模式匹配算法

    2024-04-23 09:56:01       11 阅读
  4. rabbitmq 之 无法自动创建队列的问题

    2024-04-23 09:56:01       15 阅读
  5. pandas

    2024-04-23 09:56:01       13 阅读
  6. 决策树(分类决策树)

    2024-04-23 09:56:01       15 阅读
  7. 智能小车-轮趣wheeltec(原版代码)

    2024-04-23 09:56:01       12 阅读
  8. Podman容器的原理及应用详解(一)

    2024-04-23 09:56:01       15 阅读