【剑斩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;
    }
};
相关推荐
宁静致远20211 分钟前
ARM 架构 Ubuntu 20.04 / 22.04 触摸屏设备
linux·c++·ubuntu
草莓熊Lotso2 分钟前
Linux C++ 高并发编程:从原理到手撕,线程池全链路深度解析
linux·运维·服务器·开发语言·数据库·c++·mysql
Gh0st_Lx3 分钟前
【8】分类任务原理
算法·分类·数据挖掘
WolfGang0073213 分钟前
代码随想录算法训练营 Day45 | 图论 part03
算法·图论
a里啊里啊5 分钟前
软考-软件评测师:知识点整理(六)——数据结构与算法
数据结构·算法·链表·软考·软件评测师
想带你从多云到转晴10 分钟前
06、数据结构与算法---二叉树
java·数据结构·算法
酉鬼女又兒13 分钟前
Leetcode 26.删除有序数组中的重复项 双指针巧解有序数组去重:从快慢指针到原地修改算法的精髓
java·数据结构·算法·leetcode·职场和发展·蓝桥杯·排序算法
光电笑映13 分钟前
Linux C/C++ 开发工具(下):make/Makefile、进度条小程序与 gdb 调试器
linux·c语言·c++
承渊政道14 分钟前
【动态规划算法】(斐波那契数列模型详解)
数据结构·c++·学习·算法·leetcode·macos·动态规划