leetcode 207. 课程表【拓扑排序】

拓扑排序是将有向无环图中的顶点进行排序,排序后,顶点按照总入度递增排序,即入度最少的顶点排在最前面。
该算法在实际应用中常用于确定一个依赖关系集中,各种互相依赖事件的发生顺序。再本题中就是不同课程的先修顺序。
将课程想象为图的节点,那么课程间的依赖关系便是构成图的边,使用拓扑排序便能确定(其中一种)选课顺序了。

class Solution {
    public boolean canFinish(int numCourses, int[][] prerequisites) {
        int[] indegrees = new int[numCourses];
        List<List<Integer>> adjacency = new ArrayList<>();
    
        for(int i = 0; i < numCourses; i++){
            adjacency.add(new ArrayList<>());
        } 
        //统计每个顶点的入度
        for(int[] i : prerequisites){
            indegrees[i[0]]++;
            adjacency.get(i[1]).add(i[0]);
        }
        Queue<Integer> q = new LinkedList<>();
        for(int i=0; i<numCourses; i++){
            if(indegrees [i] == 0){
                q.offer(i);
            }
        }
        while(!q.isEmpty()){
            int temp = q.poll();
            numCourses--;
            for(int cur : adjacency.get(temp)){
                if(--indegrees[cur] == 0) q.add(cur);
            }
        }
        return numCourses == 0;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值