博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
802. Find Eventual Safe States
阅读量:6428 次
发布时间:2019-06-23

本文共 1155 字,大约阅读时间需要 3 分钟。

https://leetcode.com/problems/find-eventual-safe-states/description/

class Solution {public:    vector
visited; vector
mem; // -1 unknown, 0 unsafe, 1 safe. int n; vector
eventualSafeNodes(vector
>& graph) { n = graph.size(); mem = vector
(n, -1); visited = vector
(n, false); for (int i = 0; i < n; i++) dfs(graph, i); vector
res; for (int i = 0; i < n; i++) if (mem[i] == 1) res.push_back(i); return res; } bool dfs(vector
>& graph, int i) { // check if i is evetually safe if (mem[i] != -1) return mem[i] == 1; bool res = true; if (visited[i]) {  // A loop res = false; } else { visited[i] = true; for (auto j : graph[i]) { if (!dfs(graph, j)) { res = false; break; } } // visited[i] = false; // This line is optional, since we've cached the result for i in mem. } mem[i] = res; return res; }};

  

转载于:https://www.cnblogs.com/JTechRoad/p/8985136.html

你可能感兴趣的文章
iOS9 未受信任的企业级开发者
查看>>
paper 40 :鲁棒性robust
查看>>
做一个会使用PS的前端开发
查看>>
优化MySchool数据库(事务、视图、索引)
查看>>
硬件开发之pcb---PCB抗干扰设计原则
查看>>
关于字符串循环遍历的两种方法
查看>>
使用笔记:TF辅助工具--tensorflow slim(TF-Slim)
查看>>
CCF-NOIP-2018 提高组(复赛) 模拟试题(一)
查看>>
大话设计模式读书笔记3——单例模式
查看>>
Java多线程之ReentrantLock与Condition
查看>>
实验三
查看>>
Vue 项目构建
查看>>
[Ruby on Rails系列]2、开发环境准备:Ruby on Rails开发环境配置
查看>>
在反射中如何调用类中的Setter()AndGetter()方法
查看>>
android studio adb
查看>>
框架源码系列二:手写Spring-IOC和Spring-DI(IOC分析、IOC设计实现、DI分析、DI实现)...
查看>>
asp.net编译 懒人脚本
查看>>
二分答案经典入门题:)
查看>>
为什么你需要将代码迁移到ASP.NET Core 2.0?
查看>>
思杰的雄心——软件定义的工作空间
查看>>