【剑斩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;
    }
};
相关推荐
YL200404265 小时前
048路径总和III
数据结构·dfs
z200509306 小时前
每日简单算法题——————跟着卡尔
算法
Irissgwe7 小时前
类与对象(三)
开发语言·c++·类和对象·友元
️是787 小时前
信息奥赛一本通—编程启蒙(3395:练68.3 车牌问题)
数据结构·c++·算法
Liangwei Lin7 小时前
LeetCode 118. 杨辉三角
算法·leetcode·职场和发展
计算机安禾7 小时前
【c++面向对象编程】第24篇:类型转换运算符:自定义隐式转换与explicit
java·c++·算法
鼠鼠我(‘-ωก̀ )好困7 小时前
leetGPU
算法
雪度娃娃7 小时前
转向现代C++——优先选用nullptr而不是0和NULL
开发语言·c++
我星期八休息7 小时前
Linux系统编程—基础IO
linux·运维·服务器·c语言·c++·人工智能·算法
池塘的蜗牛7 小时前
A Low-Complexity Method for FFT-based OFDM Sensing
算法