【剑斩OFFER】算法的暴力美学——力扣 207 题:课程表

一、题目描述

二、算法原理

思路:拓扑排序

入度:指向该数字的个数

出度:箭尾的个数

拓扑排序:步步的把入度为 0 的值移除或记录下来:

最移除或记录完所有的节点,如果:

想这种没有节点的入度为 0 的,就跟题目说的:永远都是学不完,进入了一个死循环;

三、代码实现

cpp 复制代码
class Solution {
public:
    bool canFinish(int n, vector<vector<int>>& prerequisites) {
        vector<vector<int>> edgs(n);//链接表
        vector<int> in(n);//入度的值

        for(auto& e : prerequisites)//建图
        {
            int a = e[0], b = e[1];// b -> a
            //b 的入度为0, a 的入度为 1
            edgs[b].push_back(a);//加入链接表
            in[a]++;
        }
        queue<int> que;//拓扑排序
        for(int i = 0; i < n; i++)
        {
            if(in[i] == 0)
                que.push(i);//找到入度为0的值入队列,为后面的 BFS 做准备
        }

        //使用 BFS
        while(que.size())
        {
            int target = que.front();//此时拿到的是度为0的值的下标
            que.pop();
            for(auto& e : edgs[target])//断开指向
            {
                in[e]--;
                if(in[e] == 0) que.push(e);
            }
        }

        for(auto& e : in)//如果度不为0,证明还有指向,也就是学习的课程呈现一个死循环,学不完
        {
            if(e != 0) return false;
        }
        return true;
    }
};
相关推荐
zyq99101_12 小时前
优化二分查找:前缀和降复杂度
数据结构·python·蓝桥杯
qyzm2 小时前
天梯赛练习(3月13日)
开发语言·数据结构·python·算法·贪心算法
逆境不可逃2 小时前
LeetCode 热题 100 之 64. 最小路径和 5. 最长回文子串 1143. 最长公共子序列 72. 编辑距离
算法·leetcode·动态规划
CoderCodingNo2 小时前
【GESP】C++五级练习题 luogu-P1182 数列分段 Section II
开发语言·c++·算法
放下华子我只抽RuiKe52 小时前
机器学习全景指南-直觉篇——基于距离的 K-近邻 (KNN) 算法
人工智能·gpt·算法·机器学习·语言模型·chatgpt·ai编程
kisshuan123963 小时前
[特殊字符]【深度学习】DA3METRIC-LARGE单目深度估计算法详解
人工智能·深度学习·算法
sali-tec3 小时前
C# 基于OpenCv的视觉工作流-章33-Blod分析
图像处理·人工智能·opencv·算法·计算机视觉
Qt学视觉3 小时前
AI2-Paddle环境搭建
c++·人工智能·python·opencv·paddle
Eward-an3 小时前
LeetCode 239. 滑动窗口最大值(详细技术解析)
python·算法·leetcode
一叶落4384 小时前
LeetCode 50. Pow(x, n)(快速幂详解 | C语言实现)
c语言·算法·leetcode