zoukankan      html  css  js  c++  java
  • [LeetCode] Course Schedule II

    Well, this problem is spiritually similar to to Course Schedule. You only need to store the nodes in the order you visit into a vector during BFS or DFS. Well, for DFS, a final reversal is required.


    BFS

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

    DFS

     1 class Solution {
     2 public:
     3     vector<int> findOrder(int numCourses, vector<pair<int, int>>& prerequisites) {
     4         vector<unordered_set<int>> graph = make_graph(numCourses, prerequisites);
     5         vector<int> toposort;
     6         vector<bool> onpath(numCourses, false), visited(numCourses, false);
     7         for (int i = 0; i < numCourses; i++)
     8             if (!visited[i] && dfs(graph, i, onpath, visited, toposort))
     9                 return {};
    10         reverse(toposort.begin(), toposort.end());
    11         return toposort;
    12     }
    13 private:
    14     vector<unordered_set<int>> make_graph(int numCourses, vector<pair<int, int>>& prerequisites) {
    15         vector<unordered_set<int>> graph(numCourses);
    16         for (auto pre : prerequisites)
    17             graph[pre.second].insert(pre.first);
    18         return graph;
    19     }
    20     bool dfs(vector<unordered_set<int>>& graph, int node, vector<bool>& onpath, vector<bool>& visited, vector<int>& toposort) { 
    21         if (visited[node]) return false;
    22         onpath[node] = visited[node] = true; 
    23         for (int neigh : graph[node])
    24             if (onpath[neigh] || dfs(graph, neigh, onpath, visited, toposort))
    25                 return true;
    26         toposort.push_back(node);
    27         return onpath[node] = false;
    28     }
    29 };
  • 相关阅读:
    366. Find Leaves of Binary Tree输出层数相同的叶子节点
    716. Max Stack实现一个最大stack
    515. Find Largest Value in Each Tree Row查找一行中的最大值
    364. Nested List Weight Sum II 大小反向的括号加权求和
    156. Binary Tree Upside Down反转二叉树
    698. Partition to K Equal Sum Subsets 数组分成和相同的k组
    244. Shortest Word Distance II 实现数组中的最短距离单词
    187. Repeated DNA Sequences重复的DNA子串序列
    java之hibernate之基于主键的双向一对一关联映射
    java之hibernate之基于主键的单向一对一关联映射
  • 原文地址:https://www.cnblogs.com/jcliBlogger/p/4605039.html
Copyright © 2011-2022 走看看