【剑斩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;
    }
};
相关推荐
Darkwanderor3 小时前
什么数据量适合用什么算法
c++·算法
超绝振刀怪4 小时前
【C++多态】
开发语言·c++
zc.ovo4 小时前
河北师范大学2026校赛题解(A,E,I)
c++·算法
py有趣4 小时前
力扣热门100题之环形链表
算法·leetcode·链表
py有趣4 小时前
力扣热门100题之回文链表
算法·leetcode·链表
programhelp_5 小时前
SIG 2026 Quant / Susquehanna OA 全攻略
人工智能·机器学习·面试·职场和发展·数据分析
测试19985 小时前
使用Python自动化生成接口测试用例
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
Kk.08025 小时前
数据结构|链表 刷题
数据结构·链表
学嵌入式的小杨同学5 小时前
STM32 进阶封神之路(三十九)FreeRTOS 临界区、挂起 / 删除、钩子函数、调度底层原理|从应用到内核深度解析
c++·stm32·单片机·嵌入式硬件·mcu·硬件架构·pcb