力扣HOT100之图论:207. 课程表

这道题第一次做,有向图判断是否有环的思路是完全忘完了,这次没有看灵神的题解,感觉笨猪爆破组的题解更加通俗易懂一些,强烈建议参考他的题解,因为图论本来就很难,光是理解起来就已经很费劲了,没有必要为了代码的简洁和优雅而忽略了代码的可读性。这道题还是用BFS来做,我们需要明确几个点:

  1. 当一门课程需要前置课程时,这门课程是有入度的,当该门课程的前置课程修完一门,则入度-1,当入度减为0时,说明该门课程的前置课程全部修完,可以直接修读。
  2. 只有当一门课程的入度为0时,才能加入队列中,从队列中取出来的课程,都是在现有的基础上可以直接修读的课程,每当取出一门课程,我们就需要将该课程的所有目标课程的入度减一(前置课程为是目标课程服务的),当有目标课程的入度被减为0时,我们需要立马将其加入到队列中
  3. 当队列为空时,说明能修读的课程都已经修读完了,只有当图中存在环时,不能修读完所有课程,因为存在循环依赖,因此我们需要定义一个变量finish来记录已经修读完毕的课程,应当在课程被从队列中弹出时(被弹出就意味着该课程被修读)标记,当循环结束时,判断修读的课程数和输入的课程总数是否相等,若不相等则一定有环。
    明白了以上几个关键要点后,代码就很容易写了。
cpp 复制代码
class Solution {
public:
    bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {
        vector<int> inDegree(numCourses, 0);    //记录每门课程的入度
        vector<vector<int>> grah(numCourses);  //使用vector存储邻接表
        //计算每门课程的入度,并构建邻接表
        for(vector<int>& prerequisite : prerequisites){
            int course = prerequisite[0];   //目标课程
            int preCourse = prerequisite[1];    //前置课程
            inDegree[course]++;    //目标课程的入度+1
            grah[preCourse].emplace_back(course);  
        }
        queue<int> My_Queue;
        //存储入度为0的课程
        for(int i = 0; i < inDegree.size(); i++){
            if(inDegree[i] == 0)
                My_Queue.push(i);
        }
        int finish = 0;  //记录已修完的课程
        while(!My_Queue.empty()){
            int pre = My_Queue.front();
            My_Queue.pop();
            finish++;
            // pre课程的所有目标课程入度-1
            for(auto course : grah[pre]){
                inDegree[course]--;
                if(inDegree[course] == 0)  //某门后续课程可以直接修读了
                    My_Queue.push(course);
            }  
        }
        return finish == numCourses;
    }
};
相关推荐
Xの哲學2 小时前
从硬中断到 softirq:Linux 软中断机制的全景解剖
linux·服务器·网络·算法·边缘计算
生信碱移2 小时前
单细胞空转CNV分析工具:比 inferCNV 快10倍?!兼容单细胞与空转的 CNV 分析与聚类,竟然还支持肿瘤的亚克隆树构建!
算法·机器学习·数据挖掘·数据分析·聚类
Brduino脑机接口技术答疑2 小时前
TDCA 算法在 SSVEP 场景中:Padding 的应用对象与工程实践指南
人工智能·python·算法·数据分析·脑机接口·eeg
keep_learning1113 小时前
Z-Image模型架构全解析
人工智能·算法·计算机视觉·大模型·多模态
点云SLAM3 小时前
Boost中Graph模块中boost::edge_capacity和boost::edge_capacity_t
数据库·算法·edge·图论·最大团·最大流算法·boost库使用
lihaihui19913 小时前
asan 内存问题分析
算法
算法与编程之美3 小时前
探索不同的损失函数对分类精度的影响.
人工智能·算法·机器学习·分类·数据挖掘
H_BB3 小时前
leetcode160:相交链表
数据结构·算法·链表
前端小L4 小时前
贪心算法专题(十五):借位与填充的智慧——「单调递增的数字」
javascript·算法·贪心算法
前端小L4 小时前
贪心算法专题(十四):万流归宗——「合并区间」
javascript·算法·贪心算法