HDU 1269 裸奔的强联通分量
看了别人博客 http://blog.csdn.net/jokes000/article/details/7538994
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <string>
#include <queue>
#include <stack>
#include <cstring>
#define CL(a,b) memset(a,b,sizeof(a))
#define ll __int64
#define TEST cout<<"TEST ***"<<endl;
#define INF 0x7ffffff0
#define MOD 1000000007
using namespace std; typedef struct myedge
{
int e,next;
}E;
E edge[];
stack <int> st; int head[],ct,tim;
int ti[],lo[],ins[],n,m; void inithead()
{
CL(head,-);
tim=;
ct=;
} void addedge(int s,int e)
{
edge[ct].e=e;edge[ct].next=head[s];head[s]=ct++;
} void targan(int i)
{
tim++;
ti[i]=tim;lo[i]=tim;
st.push(i);
ins[i]=;
int p=head[i];
int v;
while(p!=-)
{
v=edge[p].e;
if(ins[v]==)
{
lo[i]=min(lo[v],lo[i]);
}
else if(ti[v]==)
{
targan(v);
lo[i]=min(lo[i],lo[v]);
}
p=edge[p].next;
}
if(lo[i]==ti[i])
{
while(!st.empty()&&lo[st.top()]==ti[i])
{
ins[st.top()]=;
st.pop();
}
}
} int main()
{
while(scanf("%d %d",&n,&m)!=EOF)
{
if(n==&&m==)break;
int i,j,a,b;
inithead();
CL(lo,);
CL(ti,);
CL(ins,);
for(i=;i<m;i++)
{
scanf("%d %d",&a,&b);
addedge(a,b);
}
targan();
int re=;
for(i=;i<=n;i++)
{
if(lo[i]==ti[i])re++;
}
// cout<<re<<endl;
if(re==)printf("Yes\n");
else printf("No\n");
}
return ;
}
HDU 1269 裸奔的强联通分量的更多相关文章
- HDU 1269 迷宫城堡 【强联通分量(模版题)】
		
知识讲解: 在代码里我们是围绕 low 和 dfn 来进行DFS,所以我们务必明白 low 和 dfn 是干什么的? 有什么用,这样才能掌握他. 1. dfn[] 遍历到这个点的时间 2. ...
 - hdu 1269 迷宫城堡(强联通分量,基础)
		
这是一道模版题 题目 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<string.h> #include ...
 - 【强联通图 | 强联通分量】HDU 1269 迷宫城堡 【Kosaraju或Tarjan算法】
		
为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个房间(N<=10000)和M条通道(M<=100000),每个通道都是单向的,就是说若称某通道连通了A房间和B房间,只说明 ...
 - HDU 4685 Prince and Princess(二分匹配+强联通分量)
		
题意:婚配问题,但是题目并不要求输出最大匹配值,而是让我们输出,一个王子可以与哪些王妃婚配而不影响最大匹配值. 解决办法:先求一次最大匹配,如果有两个已经匹配的王妃,喜欢她们两个的有两个或者以上相同的 ...
 - HDU 5934 强联通分量
		
Bomb Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
 - [vios1023]维多利亚的舞会3<强联通分量tarjan>
		
题目链接:https://vijos.org/p/1023 最近在练强联通分量,当然学的是tarjan算法 而这一道题虽然打着难度为3,且是tarjan算法的裸题出没在vijos里面 但其实并不是纯粹 ...
 - Kosaraju算法---强联通分量
		
1.基础知识 所需结构:原图.反向图(若在原图中存在vi到vj有向边,在反向图中就变为vj到vi的有向边).标记数组(标记是否遍历过).一个栈(或记录顶点离开时间的数组). 算法描叙: :对 ...
 - [CF #236 (Div. 2) E] Strictly Positive Matrix(强联通分量)
		
题目:http://codeforces.com/contest/402/problem/E 题意:给你一个矩阵a,判断是否存在k,使得a^k这个矩阵全部元素都大于0 分析:把矩阵当作01矩阵,超过1 ...
 - UVa 11324 & 强联通分量+DP
		
题意: 一张无向图,求点集使其中任意两点可到达. SOL: 强联通分量中的点要么不选要么全都选,然后缩点DAG+DP 记录一下思路,不想写了...代码满天飞.
 
随机推荐
- nodejs个人配置
			
国内镜像,飞一般的感觉!编辑 ~/.npmrc 加入下面内容 registry = http://registry.cnpmjs.org npm config set registry http:/ ...
 - java学习笔记 (5) —— Struts2 监听器配置
			
1.创建MyListener.java 实现 PreResultLisener 接口 import com.opensymphony.xwork2.ActionInvocation; import c ...
 - ECSTORE 新建APP应用
			
1.用命令新建app // ----- window平台 ----- 直接运行 " 站点根目录/app/base/cmd.bat " 出现命令行后输入 dev:new app my ...
 - HTML5实现的视频播放器01
			
HTML5实现的视频播放器 什么是hivideo? 最近一段时间在使用PhoneGap开发一个App应用,App需要播放视频,本想直接使用html5的video,但使用它在全屏播放时不支持横屏播放 ...
 - Kafka笔记--常用指令(删除topic)
			
删除topic 首先需要设置server.properties,最后一行添加 delete.topic.enable=true 然后运行> ./kafka-topics.sh --zookeep ...
 - Linux/Unix工具与正则表达式的POSIX规范
			
http://www.infoq.com/cn/news/2011/07/regular-expressions-6-POSIX 对正则表达式有基本了解的读者,一定不会陌生『\d』.『[a-z]+』之 ...
 - WINDOWS+NGINX+DJANGO+FLUP+PYTHON起步~
			
参考的文档是 http://blog.163.com/sky20081816@126/blog/static/1647610232010824262695/ 但在实操时,作了更改之后才生效,就是#in ...
 - TVS_压敏电阻等保护类器件的布局问题
			
世上本没有垃圾,垃圾都是放错了位置的资源. 对于电路来说,保护器件就是其保护作用的关键资源,但如果放错了位置,它就是垃圾:甚至不仅是垃圾,而还可能成为祸害. 由最近承接的几起电路原理图审核项目来看,触 ...
 - KEIL简单实例
			
好久都没有用KEIL了,突然想动手,一时还真不知道从哪开始写,所以先弄个小实例,以便参考:#include <reg52.h> //加载包括一个52标准内核的头文件,里面主要是一些寄存器 ...
 - 2015必须推荐的Android框架,猿必读系列!
			
一.Guava Google 的基于java1.6的类库集合的扩展项目,包括collections, caching, primitives support, concurrency librarie ...