hdu 1269 迷宫城堡
2015-11-26 21:36
288 查看
原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1269
强联通分量裸题。。
Tarjan求强联通分量参见:https://www.byvoid.com/blog/scc-tarjan/
强联通分量裸题。。
Tarjan求强联通分量参见:https://www.byvoid.com/blog/scc-tarjan/
#include<bits/stdc++.h> using namespace std; const int N = 10100; struct Tarjan_Scc { stack<int>s; bool instack ; struct edge { int to, next; }G[N * 10]; int scc, idx, tot, dfn , low , head ; inline void init(int n) { scc = tot = idx = 0; while (!s.empty()) s.pop(); for (int i = 0; i < n + 2; i++) { head[i] = -1; instack[i] = false; dfn[i] = low[i] = 0; } } inline void add_edge(int u, int v) { G[tot].to = v, G[tot].next = head[u], head[u] = tot++; } inline void built(int m) { int u, v; while (m--) { scanf("%d %d", &u, &v); add_edge(u, v); } } inline void tarjan(int u) { dfn[u] = low[u] = ++idx; s.push(u); instack[u] = true; for (int i = head[u]; ~i; i = G[i].next) { int &v = G[i].to; if (!dfn[v]) { tarjan(v); low[u] = min(low[u], low[v]); } else if (instack[v] && dfn[v] < low[u]) { low[u] = dfn[v]; } } if (low[u] == dfn[u]) { scc++; int v = 0; do { v = s.top(); s.pop(); instack[v] = false; } while (v != u); } } inline void solve(int n, int m) { init(n); built(m); for (int i = 1; i <= n; i++) { if (!dfn[i]) tarjan(i); } puts(scc == 1 ? "Yes" : "No"); } }go; int main() { #ifdef LOCAL freopen("in.txt", "r", stdin); freopen("out.txt", "w+", stdout); #endif int n, m; while (~scanf("%d %d", &n, &m), m + n) { go.solve(n, m); } return 0; }
相关文章推荐
- Tarjan 算法 求有向图强连通分量
- java基础之多线程
- Python计算机视觉编程练习11:备忘
- Delphi之TDrawGrid绘制
- Android学习之解决ListView中item点击事件和item中Button点击事件冲突问题
- 服务器登录名、角色、数据库用户、角色、架构的关系
- 习题3-5 谜题 解题报告
- 第一篇博客,写在颓废之时
- bzoj:1654 [Usaco2006 Jan]The Cow Prom 奶牛舞会
- Delphi中的消息截获(六种方法)
- 从头认识java-10.6 finally(1)-特性
- Codeforces 295B Greg and Graph
- 【C语言】找带环单链表的环入口
- 黑马程序员——Java笔记——String类常用方法
- UITextFieldDelegate协议中各个方法调用情况
- Stat
- 20135321余佳源、20135323符运锦----实验二:固件设计
- Operating System-Thread(2) Multi-Process-Parallel vs Multi-Thread-Parallel
- 606第十周周六赛 H - 1sting 大数据处理
- Nodejs 0.10.x 之Url模块