[LeetCode] Course Schedule II

Well, this problem is spiritually the same to Course Schedule. You only need to store the node in the order you visit into a vector (well, for DFS, a final reversal may be required) during BFS or DFS.

Make sure you try this problem only after you have known how to solve Course Schedule. In fact, the code to this problem only differs to that of the first problem as descriped in the first paragraph. I have a passage about Course Schedule in this link. You may refer to it if you like.

Both BFS and DFS can be used to solve this problem using the idea of topological sort. In the third hint following the problem statement, there is a nice link to the wikipedia passage about topological sort, which includes nicely-written pseudo code for toposort in both BFS and DFS. Strong recommendations to take a look at it. It is really well explained!

Now comes the BFS code.

 1 // BFS
 2 class Solution {
 3 public:
 4     vector<int> findOrder(int numCourses, vector<pair<int, int>>& prerequisites) {
 5         vector<unordered_set<int> > graph = make_graph(numCourses, prerequisites);
 6         vector<int> degrees = compute_indegree(graph);
 7         queue<int> zeros;
 8         for (int i = 0; i < degrees.size(); i++)
 9             if (!degrees[i]) zeros.push(i);
10         vector<int> toposort;
11         while (!zeros.empty()) {
12             int zero = zeros.front();
13             zeros.pop();
14             toposort.push_back(zero);
15             for (int neigh : graph[zero]) {
16                 if (--degrees[neigh] == 0)
17                     zeros.push(neigh);
18             }
19             numCourses--;
20         }
21         if (numCourses) toposort.clear();
22         return toposort;
23     }
24 private:
25     vector<unordered_set<int> > make_graph(int numCourses, vector<pair<int, int> >& prerequisites) {
26         vector<unordered_set<int> > graph(numCourses);
27         for (auto pre : prerequisites)
28             graph[pre.second].insert(pre.first);
29         return graph;
30     }
31     vector<int> compute_indegree(vector<unordered_set<int> >& graph) {
32         vector<int> degrees(graph.size(), 0);
33         for (auto neighbors : graph)
34             for (auto neigh : neighbors)
35                 degrees[neigh]++;
36         return degrees;
37     }
38 };

Then the DFS code.

 1 // DFS
 2 class Solution {
 3 public:
 4     vector<int> findOrder(int numCourses, vector<pair<int, int>>& prerequisites) {
 5         vector<unordered_set<int> > graph = make_graph(numCourses, prerequisites);
 6         vector<int> toposort;
 7         unordered_set<int> curVisit;
 8         vector<bool> visited(numCourses, false);
 9         for (int i = 0; i < (int)graph.size(); i++) {
10             if (!visited[i] && dfs(graph, i, curVisit, visited, toposort)) {
11                     toposort.clear();
12                     return toposort;
13             }
14         }
15         reverse(toposort.begin(), toposort.end());
16         return toposort;
17     }
18 private:
19     vector<unordered_set<int> > make_graph(int numCourses, vector<pair<int, int> >& prerequisites) {
20         vector<unordered_set<int> > graph(numCourses);
21         for (auto pre : prerequisites)
22             graph[pre.second].insert(pre.first);
23         return graph;
24     }
25     bool dfs(vector<unordered_set<int> >& graph, int node, unordered_set<int>& curVisit, vector<bool>& visited, vector<int>& toposort) {
26         if (visited[node]) return false;
27         visited[node] = true;
28         curVisit.insert(node);
29         for (auto itr = graph[node].begin(); itr != graph[node].end(); itr++)
30             if (curVisit.find(*itr) != curVisit.end() || dfs(graph, *itr, curVisit, visited, toposort))
31                 return true;
32         curVisit.erase(node);
33         toposort.push_back(node);
34         return false;
35     }
36 };

 

你可能感兴趣的:(LeetCode)