The Bottom of a Graph(tarjan + 缩点)
| Time Limit: 3000MS | Memory Limit: 65536K | |
| Total Submissions: 9139 | Accepted: 3794 |
Description
Let n be a positive integer, and let p=(e1,...,en) be a sequence of length n of edges ei∈E such that ei=(vi,vi+1) for a sequence of vertices (v1,...,vn+1). Then p is called a path from vertex v1 to vertex vn+1in G and we say that vn+1 is reachable from v1, writing (v1→vn+1).
Here are some new definitions. A node v in a graph G=(V,E) is called a sink, if for every node w in G that is reachable from v, v is also reachable from w. The bottom of a graph is the subset of all nodes that are sinks, i.e., bottom(G)={v∈V|∀w∈V:(v→w)⇒(w→v)}. You have to calculate the bottom of certain graphs.
Input
Output

Sample Input
3 3
1 3 2 3 3 1
2 1
1 2
0
Sample Output
1 3
2
Source
参考代码这里:http://blog.csdn.net/ehi11/article/details/7884851
缩点:(这个概念也是看了别人的理解)先求有向图的强连通分量 , 如果几个点同属于一个强连通 , 那就给它们标上相同的记号 , 这样这几个点的集合就形成了一个缩点。
题目大意:求出度为0的强连通分量
#include<stdio.h>
#include<queue>
#include<string.h>
using namespace std;
const int M = ;
int n , m ;
int stack [M] , top = , index = ;
bool instack [M] ;
int dfn[M] , low[M] ;
int cnt = ;
vector <int> e[M] ;
int belong[M] ;
int out[M] ; void init (int n)
{
top = ;
cnt = ;
index = ;
memset (stack , - , sizeof(stack)) ;
memset (instack , , sizeof(instack)) ;
memset (dfn , - , sizeof(dfn)) ;
memset (low , - , sizeof(low)) ;
for (int i = ; i <= n ; i++)
e[i].clear () ;
memset (belong , - , sizeof(belong)) ;
memset (out , , sizeof(out)) ;
} void tarjan (int u)
{
int v ;
dfn[u] = low[u] = index++ ;
instack[u] = true ;
stack[++top] = u ;
for (int i = ; i < e[u].size () ; i++) {
v = e[u][i] ;
if (dfn[v] == -) {
tarjan (v) ;
low[u] = min (low[u] , low[v]) ;
}
else if (instack[v])
low[u] = min (low[u] , dfn[v]) ;
}
if (low[u] == dfn[u]) {
cnt++ ;
do {
v = stack[top--] ;
instack[v] = false ;
belong[v] = cnt ;
} while (u != v) ;
}
} int main ()
{
//freopen ("a.txt" , "r" , stdin) ;
int u , v ;
while (~ scanf ("%d" ,&n)) {
if (n == )
break ;
init (n) ;
scanf ("%d" , &m) ;
while (m--) {
scanf ("%d%d" , &u , &v) ;
e[u].push_back (v) ;
}
for (int i = ; i <= n ; i++) {
if (dfn[i] == -)
tarjan (i) ;
}
for (int i = ; i <= n ; i++) {
for (int j = ; j < e[i].size () ; j++) {
if (belong [i] != belong[e[i][j]])
out[belong[i]] ++;
}
}
int k = ;
for (int i = ; i <= n ; i++) {
if (out[belong[i]] == ) {
if (k++)
printf (" ") ;
printf ("%d" , i) ;
}
}
puts ("") ;
}
return ;
}
The Bottom of a Graph(tarjan + 缩点)的更多相关文章
- POJ2533&&SP1799 The Bottom of a Graph(tarjan+缩点)
POJ2553 SP1799 我们知道单独一个强连通分量中的所有点是满足题目要求的 但如果它连出去到了其他点那里,要么成为新的强连通分量,要么失去原有的符合题目要求的性质 所以只需tarjan缩点求出 ...
- POJ 2553 The Bottom of a Graph Tarjan找环缩点(题解解释输入)
Description We will use the following (standard) definitions from graph theory. Let V be a nonempty ...
- POJ 2553 The Bottom of a Graph (Tarjan)
The Bottom of a Graph Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 11981 Accepted: ...
- poj--2553--The Bottom of a Graph (scc+缩点)
The Bottom of a Graph Time Limit : 6000/3000ms (Java/Other) Memory Limit : 131072/65536K (Java/Oth ...
- [poj 2553]The Bottom of a Graph[Tarjan强连通分量]
题意: 求出度为0的强连通分量. 思路: 缩点 具体有两种实现: 1.遍历所有边, 边的两端点不在同一强连通分量的话, 将出发点所在强连通分量出度+1. #include <cstdio> ...
- POJ 2553 The Bottom of a Graph TarJan算法题解
本题分两步: 1 使用Tarjan算法求全部最大子强连通图.而且标志出来 2 然后遍历这些节点看是否有出射的边,没有的顶点所在的子强连通图的全部点,都是解集. Tarjan算法就是模板算法了. 这里使 ...
- poj 2553 The Bottom of a Graph(强连通分量+缩点)
题目地址:http://poj.org/problem?id=2553 The Bottom of a Graph Time Limit: 3000MS Memory Limit: 65536K ...
- poj 2553 The Bottom of a Graph【强连通分量求汇点个数】
The Bottom of a Graph Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 9641 Accepted: ...
- 【图论】The Bottom of a Graph
[POJ2553]The Bottom of a Graph Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 11182 ...
随机推荐
- 一个js验证类
//******************************************************************* //作者: 丁伯洋 //日期: 2006-4-27 //概要 ...
- 我最优惠网系列(1)——HTML 解析类库HtmlAgilityPack
0. 序言 在开发我最优惠网的过程中,遇到一些问题和技术点,写出来和大家分享,也是我自己对近期工作的整理和记录,预计会有解析HTML类库.本地缓存.链接跳转和C#中执行js代码技巧等方面. 1. Ht ...
- 慢牛系列四:好玩的React Native
在上次随笔(系列三)中,我试着用RN实现了一个Demo,感觉很不错,当时遇到的问题这篇文章里基本都解决了,比如导航动画问题,这篇文章里主要介绍RN的动画,学会动画以后,各种小创意都可以实现了^^ 下面 ...
- CSS 居中大全(转)
转自这里,收藏备用. <center> 不建议用了. text-align:center 在父容器里水平居中 inline 文字,或 inline 元素 vertical-align:mi ...
- 【niubi-job——一个分布式的任务调度框架】----FAQ文档
引言 本文为niubi-job的FAQ文档,该文档会无限更新.如果您在这里没有找到您想要的答案,请把问题提交到这里. FAQ 1.为什么我的所有任务总是运行在同一个节点上,而没有平均分配到所有节点上? ...
- 判断一个点是否在多边形内部,射线法思路,C#实现
感谢原作者,原理请看原作者的文章 http://www.html-js.com/article/1517 C#实现 public string rayCasting(PointF p, PointF[ ...
- 浅谈分治算法在OI中的应用
分治虽然是基本思想,但是OI中不会出裸分治让你一眼看出来,往往都是结合到找规律里面. 先来个简单的: 奇妙变换 (magic.pas/c/cpp) [问题描述] 为了奖励牛牛同学帮妈妈解决了大写中 ...
- Java设计模式-适配器模式(Adapter)
适配器模式将某个类的接口转换成客户端期望的另一个接口表示,目的是消除由于接口不匹配所造成的类的兼容性问题.主要分为三类:类的适配器模式.对象的适配器模式.接口的适配器模式.首先,我们来看看类的适配器模 ...
- Nginx简单实现网站的负载均衡
在大型网站搭建时,都会考虑如果用户量每日不断增加,大量的并发访问,会不会给网站.数据库带来崩盘的灾难.今天我们就讨论一下,现实中如何解决这些问题的一套最为容易实现的方案. 控制并发,大家都会首先考虑的 ...
- 【CodeForces 227A】Where do I Turn?叉积
题意 ABC的位置关系只有三种可能: 1.在一条直线上,输出TOWARDS A--B--C 2.AB 和BC垂直,B为直角顶点,AB左侧是C,输出LEFT C--B | A 3.AB 和BC垂直,B为 ...