POJ 2762 Going from u to v or from v to u? (Tarjan) - from lanshui_Yang
Description
Input
The first line for each case contains two integers n, m(0 < n < 1001,m < 6000), the number of rooms and corridors in the cave. The next m lines each contains two integers u and v, indicating that there is a corridor connecting room u and room v directly.
Output
Sample Input
1
3 3
1 2
2 3
3 1
Sample Output
Yes
题目大意:给你一个有向图,让你判断任意两个顶点 u和v 之间是否存在可达的路径,即 u可以到达v 或 v 可以到达 u 。
解题思路:先用tarjan缩点,然后用拓扑排序一下,排序后的序列中,如果所有相邻两个点之间均存在边,则说明原图中,任意两点之间均存在可达的路径,即输出“Yes”,否则,输出“No”。
请看代码:
#include<iostream>
#include<cstring>
#include<string>
#include<cmath>
#include<cstdio>
#include<algorithm>
using namespace std ;
const int MAXN = 1111 ;
struct Node
{
int adj ;
Node *next ;
}mem[MAXN * 6]; // 先把存放边节点的数组开好,这样能大量节省时间
int memp ;
Node *vert[MAXN] ; // 建立顶点数组
short g[MAXN][MAXN] ; // 缩点后的邻接矩阵
bool inq[MAXN] ; // 判断节点是否在栈中
int stap[MAXN] ; // 数组模拟栈
int top ;
int d[MAXN] ; // 统计 缩点后各连通分量的 入度
int tpo[MAXN] ; // 拓扑序列
bool vis[MAXN] ;
int dfn[MAXN] ;
int low[MAXN] ;
int tmpdfn ;
int belong[MAXN] ;
int n , m ;
int scnt ; // 记录强连通分量个数
void clr() // 初始化
{
memset(dfn , 0 , sizeof(dfn)) ;
memset(low , 0 , sizeof(low)) ;
memset(vert , 0 , sizeof(vert)) ;
memset(belong , -1 , sizeof(belong)) ;
memset(vis , 0 , sizeof(vis)) ;
memset(g , 0 , sizeof(g)) ;
memset(stap , -1 , sizeof(stap)) ;
memset(d , 0 , sizeof(d)) ;
memset(tpo , -1 , sizeof(tpo)) ;
memset(inq , 0 , sizeof(inq)) ;
memp = 0 ;
top = -1 ;
scnt = -1 ;
tmpdfn = 0 ;
}
void tarjan(int u)
{
vis[u] = 1 ;
dfn[u] = low[u] = ++ tmpdfn ;
stap[++ top] = u ;
inq[u] = true ;
Node *p = vert[u] ;
while (p != NULL)
{
int v = p -> adj ;
if(!vis[v])
{
tarjan(v) ;
low[u] = min(low[u] , low[v]) ;
}
else if(inq[v]) // 如果点v还在栈中
{
low[u] = min(low[u] , dfn[v]) ;
}
p = p -> next ;
}
if(dfn[u] == low[u]) // 缩点
{
scnt ++ ;
int tmp = stap[top --] ;
do
{
tmp = stap[top --] ;
inq[tmp] = false ;
belong[tmp] = scnt ;
}while(tmp != u) ;
}
}
void build()
{
Node * p ;
int i ;
for(i = 1 ; i <= n ; i ++)
{
p = vert[i] ;
while (p)
{
int tv = p -> adj ;
int x = belong[i] ;
int y = belong[tv] ;
g[belong[i]][belong[tv]] = 1 ;
if(x != y)
d[y] ++ ;
p = p -> next ;
}
}
}
void topo() // 拓扑排序
{
int k ;
for(k = 0 ; k <= scnt ; k ++)
{
int i ;
for(i = 0 ; i <= scnt ; i ++)
{
if(d[i] == 0)
break ;
}
tpo[k] = i ;
d[i] = -1 ;
int j ;
for(j = 0 ; j <= scnt ; j ++)
{
if(i != j)
d[j] -= g[i][j] ;
}
}
}
void init()
{
scanf("%d%d" , &n , &m) ;
int i , j ;
clr() ;
int root ;
for(i = 0 ; i < m ; i ++)
{
int a , b ;
scanf("%d%d" , &a , &b) ;
Node *p = &mem[memp] ;
p -> adj = b ;
p -> next = vert[a] ;
vert[a] = p ; memp ++ ;
}
for(i = 1 ; i <= n ; i ++) // 注意此处,保证图中每个节点都被访问
{
if(!vis[i])
tarjan(i) ;
}
build() ;
topo() ;
bool flag = true ;
for(i = 0 ; i < scnt ; i ++)
{
if(!g[ tpo[i] ][ tpo[i + 1] ])
{
flag = false ;
break ;
}
}
if(flag)
puts("Yes") ;
else
puts("No") ;
}
int main()
{
int T ;
scanf("%d" , &T) ;
while (T --)
{
init() ;
}
return 0 ;
}
POJ 2762 Going from u to v or from v to u? (Tarjan) - from lanshui_Yang的更多相关文章
- POJ 2186 Popular Cows(Tarjan)
http://poj.org/problem?id=2186 题意 :给你n头牛,m对关系,每对关系由两个编号组成,u和v代表着u认为v是受欢迎的,如果1认为2是受欢迎的,2认为3是受欢迎的,那1认为 ...
- POJ 1144 Network(Tarjan)
题目链接 题意 : 找出割点个数. 思路 : Tarjan缩点,u是割点的充要条件是:u要么是具有两个以上子女的深度优先生成树的根,要么不是根,而有一个子女v满足low[v]>=dfn[u]. ...
- POJ 3177 Redundant Paths(Tarjan)
题目链接 题意 : 一个无向连通图,最少添加几条边使其成为一个边连通分量 . 思路 :先用Tarjan缩点,缩点之后的图一定是一棵树,边连通度为1.然后找到所有叶子节点,即度数为1的节点的个数leaf ...
- POJ 1236 Network of Schools(tarjan)题解
题意:一个有向图.第一问:最少给几个点信息能让所有点都收到信息.第二问:最少加几个边能实现在任意点放信息就能传遍所有点 思路:把所有强连通分量缩成一点,然后判断各个点的入度和出度 tarjan算法:问 ...
- poj 1236+hdu2767 有向图 缩点+看度数(tarjan)
1236题意:一个有向图,1,求至少从几个点出发可以遍历该图,2:,求至少添加多少边,使强连通.而,HDU的只有后面一问. 解;先缩点,第一问只需找所有入度为0的点即可.,第2问,max(入度为0的点 ...
- POJ 1236 Network of Schools(tarjan)
Network of Schools Description A number of schools are connected to a computer network. Agreements h ...
- POJ 1236 Network of Schools (Tarjan)
Network of Schools Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 22745 Accepted: 89 ...
- POJ 1236 Network of Schools(tarjan求强连通分量+思维)
题目链接:http://poj.org/problem?id=1236 题目大意: 给你一个网络(有向图),有两个任务: ①求出至少同时需要几份副本可以使得整个网络都获得副本 ②至少添加多少信息表(有 ...
- POJ 2762 Going from u to v or from v to u? (强连通分量缩点+拓扑排序)
题目链接:http://poj.org/problem?id=2762 题意是 有t组样例,n个点m条有向边,取任意两个点u和v,问u能不能到v 或者v能不能到u,要是可以就输出Yes,否则输出No. ...
随机推荐
- 浅谈Qt事件的路由机制:鼠标事件
请注意,本文是探讨文章而不是教程,是根据实验和分析得出的结果,可能是错的,因此欢迎别人来探讨和纠正. 这几天对于Qt的事件较为好奇,平时并不怎么常用,一般都是用信号,对于事件的处理,一般都是需要响应键 ...
- leetcode Longest Common Prefix python
class Solution(object): def longestCommonPrefix(self, strs): """ :type strs: List[str ...
- C++中的string
要想使用标准C++中string类,必须要包含 #include <string>// 注意是<string>,不是<string.h>,带.h的是C语言中的头文件 ...
- Ie浏览器TextBox文本未居中
Ie浏览器TextBox文本未居中,而其他浏览器无问题时,可能原因是未设置垂直居中 vertical-align:middle
- Unity 4.2.0 官方最新破解版(Unity3D 最新破解版,3D游戏开发工具和游戏引擎套件)
Unity是一款跨平台的游戏开发工具,从一开始就被设计成易于使用的产品.作为一个完全集成的专业级应用,Unity还包含了价值数百万美元的功能强大的游戏引擎.Unity作为一个游戏开发工具,它的设计主旨 ...
- Web开发者需具备的8个好习惯
优秀的Web开发人员工作效率更高,因为他们拥有丰富的经验和良好的习惯.作者Gregor Dorfbauer分享了用于Web开发中的8个好习惯,这些良好的工作习惯不仅能提高效率,还能让您创建更加优秀的应 ...
- Oracle SQL CPU占用高
Oracle数据库经常会遇到CPU利用率很高的情况,这种时候大都是数据库中存在着严重性能低下的SQL语句,这种SQL语句大大的消耗了CPU资源,导致整个系统性能低下.当然,引起严重性能低下的SQL语句 ...
- WebGL是一种3D绘图标准,这种绘图技术标准允许把JavaScript和OpenGL ES 2.0结合在一起
WebGL是一种3D绘图标准,这种绘图技术标准允许把JavaScript和OpenGL ES 2.0结合在一起,通过增加OpenGL ES 2.0的一个JavaScript绑定,WebGL可以为HTM ...
- Android实现左右滑动指引效果
本文介绍Android中实现左右滑动的指引效果. 关于左右滑动效果,我在以前的一篇博文中提到过,有兴趣的朋友可以查看:http://www.cnblogs.com/hanyonglu/archive/ ...
- Android应用开发基础篇(4)-----TabHost(选项卡)
一.概述 TabHost是一种用来显示标签的组件,不清楚?看一下来电通这个应用就知道了.这个组件用起来与其他组件不太一样,它需要继承TabActivity这个类,还有它的布局文件与我们平时用的也有些不 ...