day69(1.28)——leetcode面试经典150

207. 课程表

207. 课程表

竟然考我拓扑排序!!!

题目:

题解:

java 复制代码
class Solution {
    public boolean canFinish(int numCourses, int[][] prerequisites) {
        //用拓扑排序
        //创建映射表
        Map<Integer, List<Integer>> map = new HashMap<>();
        //创建记录要想学习某个课程,必须先学习几门课程,作为入度数
        int[] pres = new int[numCourses];
        //进行初始化映射表
        for(int i=0; i<numCourses; i++) {
            map.put(i, new ArrayList<Integer>());
        }
        //将prerequisites数组中的数进行处理
        for(int i=0;i<prerequisites.length;i++) {
            int course = prerequisites[i][0];
            int preCourse = prerequisites[i][1];
            map.get(preCourse).add(course);
            pres[course]++;
        }
        //创建队列
        Queue<Integer> queue = new LinkedList<>();
        for(int i=0;i<numCourses;i++) {
            if(pres[i]==0) {
                queue.offer(i);
            }
        }
        //创建变量用来表示已经学习的课程
        int learned = 0;
        //进行bfs搜索
        while(queue.size()>0) {
            //获取队列中的值
            int t = queue.poll();
            learned++;
            //查看先修课程
            List<Integer> list = map.get(t);
            for(Integer c:list) {
                pres[c]--;
                if(pres[c]==0) {
                    queue.offer(c);
                }
            }
        }
        //直接返回learned与numCourses比较的结果
        return learned==numCourses;
    }
}
相关推荐
AI小老六1 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术2 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize3 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考16 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队20 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC2 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC2 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK2 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
_清歌2 天前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法