【剑斩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;
    }
};
相关推荐
谁刺我心3 小时前
【蓝桥杯刷题环境】VScode插件算法刷题Competitive Companion
职场和发展·蓝桥杯
孞㐑¥3 小时前
算法—链表
开发语言·c++·经验分享·笔记·算法
f狐0狸x3 小时前
【C++修炼之路】C++容器:stack、queue、deque 基本用法详解
c++·stl
学嵌入式的小杨同学3 小时前
【Linux 封神之路】文件操作 + 时间编程实战:从缓冲区到时间格式化全解析
linux·c语言·开发语言·前端·数据库·算法·ux
xqqxqxxq3 小时前
结构体(Java 类)实战题解笔记(持续更新)
java·笔记·算法
会开花的二叉树3 小时前
高性能定时器:时间轮算法的工程实践
算法
大江东去浪淘尽千古风流人物4 小时前
【LingBot-Depth】Masked Depth Modeling for Spatial Perception
人工智能·算法·机器学习·概率论
Ronaldinho Gaúch4 小时前
leetcode279完全平方数
c++·算法·动态规划
王老师青少年编程4 小时前
2024信奥赛C++提高组csp-s复赛真题及题解:超速检测
c++·真题·csp·信奥赛·csp-s·提高组·超速检测