当前位置:   article > 正文

leetcode802——Find Eventual Safe States

find eventual safe states

题目大意:从一个结点出发,最终能走到一个没有出边的点,那么这个起始点称为安全点。给出有向图的邻接表,问图里哪些点是安全点。

分析:

方法一:dfs。这道题的意思就是看从哪些点出发没有能回到原点的环存在。给图中的结点上色,初始化为0号色(color[i]=0表示没访问过该结点),dfs时遍历到的结点染1号色(表示访问过该节点),遍历邻接表判断如果无环则该节点染2号色(表示安全无环)。

方法二:拓扑排序。安全节点=无出边。将图中的所有边反向(注意题中给的graph是邻接表,不是leetcode210中给出的边集合),此时安全节点=无入边的点(入度为0),与安全节点相连的点也是安全节点,所以将入度为0的点和它的出边删掉后,剩下的入度为0的点也是安全节点,这一过程就是拓扑排序的过程。

代码:

方法一:dfs

  1. class Solution {
  2. public:
  3. vector<int> eventualSafeNodes(vector<vector<int>>& graph) {
  4. int n = graph.size();
  5. vector<int> color(n);
  6. vector<int> ans;
  7. for(int i = 0;i < n;i++){ //dfs每个结点判断是否有环
  8. if(dfs(i,color,graph))
  9. ans.push_back(i);
  10. }
  11. return ans;
  12. }
  13. bool dfs(int i,vector<int>& color,vector<vector<int>>& graph){
  14. if(color[i]) return color[i] == 2; //如果染色是安全状态2就返回true
  15. color[i] = 1; //初始染1号色,相当于标记这次dfs过程中访问过它,但它的状态不确定是否安全
  16. for(auto nei : graph[i]){
  17. // 邻接节点不安全 || 邻接节点的邻接节点不安全
  18. if(color[nei] == 1 || !dfs(nei,color,graph))
  19. return false;
  20. }
  21. color[i] = 2;
  22. return true;
  23. }
  24. };

方法二:拓扑排序

  1. class Solution {
  2. public:
  3. vector<int> eventualSafeNodes(vector<vector<int>>& graph) {
  4. vector<vector<int>> pre(graph.size()); //记录每个节点的后续结点
  5. vector<int> degree(graph.size(),0); //记录每个结点的入度
  6. for (int i = 0;i < graph.size();i++) {
  7. for(int j = 0;j < graph[i].size();j++){
  8. degree[i]++;
  9. pre[graph[i][j]].push_back(i);
  10. }
  11. }
  12. queue<int> q; //队列维护入度为0的结点
  13. for(int i = 0;i < graph.size();i++){
  14. if(degree[i] == 0) q.push(i);
  15. }
  16. vector<int> schedule;
  17. while(!q.empty()){
  18. int now = q.front();
  19. q.pop();
  20. schedule.push_back(now);
  21. for(int i = 0;i < pre[now].size();i++){
  22. degree[pre[now][i]]--;
  23. if(degree[pre[now][i]] == 0) q.push(pre[now][i]);
  24. }
  25. }
  26. sort(schedule.begin(),schedule.end());
  27. return schedule;
  28. }
  29. };

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/爱喝兽奶帝天荒/article/detail/995288
推荐阅读
相关标签
  

闽ICP备14008679号