HD1269迷宫城堡(有向图 && 划分连通块)
迷宫城堡
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 11231 Accepted Submission(s): 5030
1 2
2 3
3 1
3 3
1 2
2 3
3 2
0 0
No
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <algorithm>
#include <stack>
#include <vector>
using namespace std;
const int Max = ;
vector<int> gra[Max];
stack<int> sta;
int dfn[Max], low[Max];
int Instack[Max]; // 在不在栈中
vector<int> Component[Max]; //为每个连通块开一个数组存每个连通块的点
int InComponent[Max]; // 在哪个连通块中
int index, ComponentNumber; // index就是访问时间,componentNumber就是连通块数量
int n, m;
int Min(int x, int y)
{
return x > y ? y : x;
}
void init()
{
index = ComponentNumber = ;
memset(dfn, , sizeof(dfn));
memset(low, , sizeof(low));
memset(Instack, , sizeof(Instack));
for(int i = ; i <= n; i++)
{
gra[i].clear();
Component[i].clear();
}
while(!sta.empty())
sta.pop();
}
void input()
{
int a, b;
for(int i = ; i <= m; i++)
{
scanf("%d%d", &a, &b);
gra[a].push_back(b);
}
}
void tarjan(int u)
{
low[u] = dfn[u] = ++index;
sta.push(u);
Instack[u] = ; // u进栈
int len = gra[u].size();
for(int i = ; i < len; i++)
{
int t = gra[u][i];
if(!Instack[t]) // 也就是没访问的意思
{
tarjan(t);
low[u] = Min(low[u], low[t]);
}
else if(Instack[t] == )
{
low[u] = Min(low[u], dfn[t]);
}
}
if(dfn[u] == low[u]) // 相等的话找到一个连通块
{
++ComponentNumber;
while(!sta.empty())
{
int x = sta.top();
sta.pop();
Instack[x] = ;
Component[ComponentNumber].push_back(x); //x属于componentNumber连通块
InComponent[x] = ComponentNumber;
if(x == u)
break;
}
}
}
void solve()
{
for(int i = ; i <= n; i++)
{
if(!dfn[i])
tarjan(i); }
if(ComponentNumber > )
printf("No\n");
else
printf("Yes\n");
}
int main()
{
while(scanf("%d%d", &n, &m) != EOF)
{
if(n == && m == )
break;
init();
input();
solve();
}
}
HD1269迷宫城堡(有向图 && 划分连通块)的更多相关文章
- HDU 1269 -- 迷宫城堡【有向图求SCC的数目 && 模板】
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- 迷宫城堡 HDU - 1269 判断有向图是否是强连通图
为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个房间(N<=10000)和M条通道(M<=100000),每个通道都是单向的,就是说若称某通道连通了A房间和B房间,只说明可以 ...
- HDU1269迷宫城堡(裸Tarjan有向图求强连通分量个数)
迷宫城堡Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
- P1141 01迷宫 dfs连通块
题目描述 有一个仅由数字000与111组成的n×nn \times nn×n格迷宫.若你位于一格0上,那么你可以移动到相邻444格中的某一格111上,同样若你位于一格1上,那么你可以移动到相邻444格 ...
- HDU 1269 迷宫城堡(判断有向图强连通分量的个数,tarjan算法)
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- P1141 01迷宫(连通块模板)
题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任务是:对于给定的迷宫, ...
- HDU 1269 迷宫城堡(向量)(Tarjan模版题)
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- 迷宫城堡+算法讲解【tarjian算法】
Tarjan 算法 参考博客:https://www.cnblogs.com/shadowland/p/5872257.html 算法讲解 Tarjan 算法一种由Robert Tarjan提出的求解 ...
- hdu 1269 迷宫城堡 强连通分量
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
随机推荐
- Socket网络编程--FTP客户端
Socket网络编程--FTP客户端(1)(Windows) 已经好久没有写过博客进行分享了.具体原因,在以后说. 这几天在了解FTP协议,准备任务是写一个FTP客户端程序.直接上干货了. 0.了解F ...
- JavaScript学习笔记-简单的计时钟表
<!DOCTYPE html> <html lang="en" xmlns="http://www.w3.org/1999/xhtml"> ...
- javascript: return return false
一:代码(王工)var flag=true; $(function(){ $("#ff").submit(function(){ // 表单submit事件 registerUse ...
- springMvc对json的支持
实体类: public class User { private String id; //有这个注解的属性,不会转换为json @JsonIgnore private String name; .. ...
- 2016年GitHub 排名前 100 的安卓、iOS项目简介(收藏)
排名完全是根据 GitHub 搜索 Java 语言选择 (Best Match) 得到的结果, 然后过滤了跟 Android 不相关的项目, 所以排名并不具备任何官方效力, 仅供参考学习, 方便初学者 ...
- 【日常笔记】java spring 注解读取文件
获取后缀文件 <!-- 注解读取properties文件开始 @Value("#{configProperties['userPageSize']}")private Str ...
- [转]PL/SQLDeveloper导入导出Oracle数据库方法
原文地址:http://www.2cto.com/database/201405/305452.html 1.Oracle数据库导出步骤 1.1 Tools→Export User Objects.. ...
- Eclipse 中 安装 SVN 插件
方法一:使用Eclipse 安装向导安装 1.测试所指环境 Eclipse 4.5/Mars 2.svn 插件的官方网站: http://subclipse.tigris.org 3.打开eclip ...
- 【USACO 2.1】Sorting A Three-Valued Sequence
/* TASK: sort3 LANG: C++ URL: http://train.usaco.org/usacoprob2?a=RkPIMxsFWzm&S=sort3 SOLVE: n个数 ...
- Urtext的使用
UITextField 是UIControl的子类,UIControl又是UIView的子类,所以也是一个视图,只不过比UIView多了两个功能,1.文字显示,2.文本编辑 使用过程分四步: 1.创建 ...