程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> leetcode 207: Course Schedule

leetcode 207: Course Schedule

編輯:C++入門知識

leetcode 207: Course Schedule


Course Schedule

Total Accepted: 3707 Total Submissions: 18102

There are a total of n courses you have to take, labeled from 0 ton - 1.

Some courses may have prerequisites, for example to take course 0 you have to first take course 1, which is expressed as a pair:[0,1]

Given the total number of courses and a list of prerequisite pairs, is it possible for you to finish all courses?

For example:

2, [[1,0]]

There are a total of 2 courses to take. To take course 1 you should have finished course 0. So it is possible.

2, [[1,0],[0,1]]

There are a total of 2 courses to take. To take course 1 you should have finished course 0, and to take course 0 you should also have finished course 1. So it is impossible.

Note:
The input prerequisites is a graph represented by a list of edges, not adjacency matrices. Read more abouthow a graph is represented.

[思路]

此問題等價於 圖(or forest)中有無環的存在.

使用topological sorting, 成功sort後,如果prerequisite沒有空,則沒有環.

[CODE]

 

public class Solution {
    // [4, 3] [3,2] [2,1]
    //init check.
    public boolean canFinish(int numCourses, int[][] prerequisites) {
        Set pre = new HashSet();
        for(int[] e : prerequisites) {
            pre.add(e);
        }
        
        int n = pre.size();
        if(n > numCourses*(numCourses-1)/2) return false;
        
        while(!getEnds(pre).isEmpty() ){};
        return pre.isEmpty();
    }
    // [1,2] [2, 3] [3,4]
    private Set getEnds(Set pre) {
        Set set = new HashSet();
        for(int[] arr : pre) {
            set.add(arr[0]);
        }
        
        for(int[] arr: pre) {
            set.remove(arr[1]);
        }
        
        Iterator iter = pre.iterator();  
        while(iter.hasNext() ) {
            int[] arr = iter.next();
            if(set.contains(arr[0]) ) iter.remove();
        }
        return set;
    }
}

 


 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved