首页 > 其他 > 详细

leetcode(210)课程表2

时间:2019-07-09 13:11:02      阅读:102      评论:0      收藏:0      [点我收藏+]

课程表2

解题思路:dfs+(邻接矩阵、邻接表)+状态机

要判断是否有环,一定要加上状态机,这里的degree存储的就是状态机:-1(没有被访问)、0(正在被访问)、1(已经被访问)

class Solution {
    public int[] findOrder(int numCourses, int[][] prerequisites) {
        int len = prerequisites.length;
        boolean[][] queue = new boolean[numCourses][numCourses];
        for(int[] p : prerequisites){
           queue[p[0]][p[1]]=true; 
        }
        int[] degree = new int[numCourses];
        for(int i=0;i<numCourses;i++){
           degree[i] = -1; 
        }
        List<Integer> res = new ArrayList<>();
        for(int i=0;i<numCourses;i++){
            if(dfs(queue,degree,res,numCourses,i)){
                
            }else{
                return new int[0];
            }
        }
        int[] result = new int[numCourses];
        int t = 0;
        for(Integer i :res){
            result[t++]=i;
        }
        return result;
    }
    public boolean dfs(boolean[][] queue,int[] degree,List<Integer> res,int numCourses,int p){
        if(degree[p]==1){
            return true;
        }
        if(degree[p]==0){
            return false;
        }
        if(degree[p]==-1){
            degree[p]=0;
            for(int i=0;i<numCourses;i++){
                if(!queue[p][i]){
                    continue;
                }
                if(dfs(queue,degree,res,numCourses,i)){
                }else{
                    return false;
                }
            }
            degree[p]=1;
            res.add(p);
            return true;
        }
        return true;
    }
}

 方法2

解题思路:拓扑排序

leetcode(210)课程表2

原文:https://www.cnblogs.com/erdanyang/p/11156166.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!