题目连接

http://acm.hdu.edu.cn/showproblem.php?pid=1269

迷宫城堡

Description

为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个房间(N<=10000)和M条通道(M<=100000),每个通道都是单向的,就是说若称某通道连通了A房间和B房间,只说明可以通过这个通道由A房间到达B房间,但并不说明通过它可以由B房间到达A房间。Gardon需要请你写个程序确认一下是否任意两个房间都是相互连通的,即:对于任意的i和j,至少存在一条路径可以从房间i到房间j,也存在一条路径可以从房间j到房间i。

Input

输入包含多组数据,输入的第一行有两个数:N和M,接下来的M行每行有两个数a和b,表示了一条通道可以从A房间来到B房间。文件最后以两个0结束。

Output

对于输入的每组数据,如果任意两个房间都是相互连接的,输出"Yes",否则输出"No"。

Sample Input

3 3
1 2
2 3
3 1
3 3
1 2
2 3
3 2
0 0

Sample Output

Yes
No

强联通分量裸题。。

Tarjan求强联通分量参见:https://www.byvoid.com/blog/scc-tarjan/

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int N = 10100;
  4. struct Tarjan_Scc {
  5. stack<int>s;
  6. bool instack[N];
  7. struct edge { int to, next; }G[N * 10];
  8. int scc, idx, tot, dfn[N], low[N], head[N];
  9. inline void init(int n) {
  10. scc = tot = idx = 0;
  11. while (!s.empty()) s.pop();
  12. for (int i = 0; i < n + 2; i++) {
  13. head[i] = -1;
  14. instack[i] = false;
  15. dfn[i] = low[i] = 0;
  16. }
  17. }
  18. inline void add_edge(int u, int v) {
  19. G[tot].to = v, G[tot].next = head[u], head[u] = tot++;
  20. }
  21. inline void built(int m) {
  22. int u, v;
  23. while (m--) {
  24. scanf("%d %d", &u, &v);
  25. add_edge(u, v);
  26. }
  27. }
  28. inline void tarjan(int u) {
  29. dfn[u] = low[u] = ++idx;
  30. s.push(u);
  31. instack[u] = true;
  32. for (int i = head[u]; ~i; i = G[i].next) {
  33. int &v = G[i].to;
  34. if (!dfn[v]) {
  35. tarjan(v);
  36. low[u] = min(low[u], low[v]);
  37. } else if (instack[v] && dfn[v] < low[u]) {
  38. low[u] = dfn[v];
  39. }
  40. }
  41. if (low[u] == dfn[u]) {
  42. scc++;
  43. int v = 0;
  44. do {
  45. v = s.top(); s.pop();
  46. instack[v] = false;
  47. } while (v != u);
  48. }
  49. }
  50. inline void solve(int n, int m) {
  51. init(n);
  52. built(m);
  53. for (int i = 1; i <= n; i++) {
  54. if (!dfn[i]) tarjan(i);
  55. }
  56. puts(scc == 1 ? "Yes" : "No");
  57. }
  58. }go;
  59. int main() {
  60. #ifdef LOCAL
  61. freopen("in.txt", "r", stdin);
  62. freopen("out.txt", "w+", stdout);
  63. #endif
  64. int n, m;
  65. while (~scanf("%d %d", &n, &m), m + n) {
  66. go.solve(n, m);
  67. }
  68. return 0;
  69. }

hdu 1269 迷宫城堡的更多相关文章

  1. HDU 1269 迷宫城堡(强连通)

    HDU 1269 迷宫城堡 pid=1269" target="_blank" style="">题目链接 题意:中文题 思路:强连通模板题 代 ...

  2. hdu 1269 迷宫城堡 强连通分量

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  3. HDU 1269 迷宫城堡(判断有向图强连通分量的个数,tarjan算法)

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  4. hdu 1269 迷宫城堡 最简单的联通图题 kosaraju缩点算法

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Problem Des ...

  5. hdu 1269 迷宫城堡(Targin算法)

    ---恢复内容开始--- 迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  6. HDU 1269.迷宫城堡-Tarjan or 双向DFS

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  7. HDU 1269 迷宫城堡 (Kosaraju)

    题目链接:HDU 1269 Problem Description 为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个房间(N<=10000)和M条通道(M<=100000), ...

  8. HDU 1269 迷宫城堡(DFS)

    迷宫城堡 Problem Description 为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个房间(N<=10000)和M条通道(M<=100000),每个通道都是单向的 ...

  9. HDU 1269 迷宫城堡(向量)(Tarjan模版题)

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

随机推荐

  1. button的type属性

    今天为看懂一段js代码纠结了很久,搞不明白数据是如何实现post,因为button没有规定属性,其次对submit事件没太搞明白.忽然想起默认属性这个概念,豁然开朗,啊~ 1.请始终为按钮规定 typ ...

  2. Tasks、 activity 及 activity stack

    一. Activity的四种加载模式 Activity之间的跳转,或者说加载一个新的Activity,一般对于开发者来说,都不是一个太难的问题.直到后来随着不断的深入,才发现原来Activity的加载 ...

  3. Leaf-spine data center architectures

    http://longwhiteclouds.com/2015/03/26/configuring-scalable-low-latency-l2-leaf-spine-network-fabrics ...

  4. 获取本地IP地址信息

    2012-06-05    /// <summary>         /// 获取本地IP地址信息         /// </summary>         void G ...

  5. webstorm & phpstorm破解

    webstorm: http://idea.qinxi1992.cn/ http://idea.goxz.gq http://v2mc.net:1017 http://idea.imsxm.com h ...

  6. CentOS 6.x 播放 mp3 音乐 —— 成功

    参考:http://blog.chinaunix.net/uid-14735472-id-3472898.html centos 6.x  添加 rpmforge 源--- CentOS 6.x 安装 ...

  7. about control %CPU

    #include <stdio.h> #include <unistd.h> #include <stdlib.h> #define timesize 200000 ...

  8. 如何更新Linux源

    首先需要自己收藏几个可以得到Linux源的站点,比如:http://mirrors.163.com/ (163的镜像站):可以百度搜索[Linux镜像站]: 下面这些镜像站,转自:http://www ...

  9. Dev的DocumentManager添加窗体

    1.DocumentManager要设置自己的MdiParent属性 2.主窗体设置IsMidContainer为True 3.要生成的窗体设置MdiParent为主窗体 4.正常创建窗体,然后就可以 ...

  10. 5.21_启程日本二面_1 vs 1

    昨天上午刚群面完,晚上7点左右就接到了电话.面试官就两位菇凉,看来她们也是很辛苦.今天下午3点 1 vs 1,在一家咖啡店里,主要是询问下去日本的意愿是否足够强烈.太老实,这里实话实说,也没有表现出非 ...