hot100-48课程表

帖子仅个人学习用途,主要参考的资料是小红书小熊饼干老师和尼布斯老师。

春招加油!

一、题目

判断 有向图 中是否存在环

二、思路

将课程及其先修关系建模为一个有向图,其中课程是节点,先修关系是有向边(如 [a, b] 表示 b → a),问题转化为判断该有向图是否存在环;若存在环,则无法完成所有课程,否则可以。

使用拓扑排序,通过构建邻接表表示图、入度数组记录每个节点的依赖数,将入度为 0 的课程加入队列,依次"学习"并减少其后继课程的入度,重复此过程,若最终能处理完所有课程(即访问节点数等于课程总数),说明图中无环,返回 true,否则返回 false。

三、代码

复制代码
class Solution {
    public boolean canFinish(int numCourses, int[][] prerequisites) {
        //创建邻接表 graph[i] 存储课程i的后继课程
        List<List<Integer>> graph = new ArrayList<>();
        for(int i =0; i<numCourses;i++){
            graph.add(new ArrayList<>());
        }
        //构建入度数组 inDegree[i] 表示课程 i 的前置课程数量
        int[] inDegree = new int[numCourses];
        for(int[] pre : prerequisites){
            int next = pre[0];//要上的课程
            int prev = pre[1];//前置课程
            graph.get(prev).add(next);//构建邻接表
            inDegree[next]++;
        }
        //初始化队列,将所有入度为0的课程入队
        Queue<Integer> queue = new LinkedList<>();
        for(int i=0;i<numCourses;i++){
            if(inDegree[i] == 0){
                queue.offer(i);
            }
        }
        int visited = 0;//上过的课程,已完成的课程
        // BFS 遍历队列
        while(!queue.isEmpty()){
            int course = queue.poll();//取出可选的课程
            visited++;//完成的课程计数
            for(int next : graph.get(course)){//遍历学完的这门课的后置课程
                inDegree[next]--;//减少依赖入度
                if(inDegree[next] == 0){//如果入度为0,则可学
                    queue.offer(next);
                }
            }
        }
        //如果访问的课程数量等于总课程数,则学完了说明无环
        return visited == numCourses;

    }
}

graph:邻接表,存储课程之间的依赖关系(边),学完A这个前置课程还能学谁

inDegree:入度数组,记录每门课还剩多少先修课程未完成,B还差几门课(还有几门前置课程)才能学

queue:队列,存放当前可学的课程(BFS遍历),当前可以学的课程

相关推荐
那个村的李富贵5 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿5 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
琹箐5 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia16 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了6 小时前
数据结构之树(Java实现)
java·算法
算法备案代理6 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.6 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
野犬寒鸦7 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总7 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow68897 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法