http://poj.org/problem?id=3180

//#include<bits/stdc++.h>
#include<iostream>
#include<cstdio>
#include<iomanip>
#include<cmath>
#include<algorithm>
#include<vector>
#include<cstring>
#include<queue>
#include<map>
#include<string>
#include<stack>
#define fi first
#define se second
#define INF 0x3f3f3f3f
#define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0)
#define pqueue priority_queue
#define NEW(a,b) memset(a,b,sizeof(a))
#define lowbit(x) ((x)&(-x))
const double pi=4.0*atan(1.0);
const int maxn=1e5+;
typedef long long LL;
typedef unsigned long long ULL;
const LL mod=1e9+;
const ULL base=1e7+;
using namespace std;
struct node{
int to,nxt;
}g[maxn*];
int head[maxn];
int cnt=;
void add(int u,int v){
g[cnt].to=v;
g[cnt].nxt=head[u];
head[u]=cnt++;
}
int deep=;
int dfn[maxn],low[maxn];
bool vis[maxn];
int Stack[maxn];
int tail=;
int ans=;
void tarjan(int u){
dfn[u]=++deep;
low[u]=deep;
Stack[++tail]=u;
vis[u]=;
int t=head[u];
int r=;
while(t!=-){
if(!dfn[g[t].to]){
tarjan(g[t].to);
low[u]=min(low[u],low[g[t].to]);
}
else{
if(vis[g[t].to]){
low[u]=min(low[u],low[g[t].to]);
}
}
t=g[t].nxt;
}
if(dfn[u]==low[u]){
while(Stack[tail]!=u){
vis[Stack[tail]]=;
tail--;
r=;
}
vis[Stack[tail]]=;
tail--;
}
ans+=r;
}
int main(){
memset(head,-,sizeof(head));
int n,m,x,y;
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++){
scanf("%d%d",&x,&y);
add(x,y);
}
for(int i=;i<=n;i++){
if(!dfn[i]){
tarjan(i);
}
}
cout<<ans<<endl;
}

无向图缩点

http://codeforces.com/group/w1oiqifZbS/contest/652/problem/E

#include<bits/stdc++.h>
#define fi first
#define se second
#define INF 0x3f3f3f3f
#define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0)
#define pqueue priority_queue
#define NEW(a,b) memset(a,b,sizeof(a))
#define lowbit(x) ((x)&(-x))
const double pi=4.0*atan(1.0);
const int maxn=3e5+;
typedef long long LL;
typedef unsigned long long ULL;
const LL mod=1e9+;
const ULL base=1e7+;
using namespace std;
struct node{
int to,nxt;
bool val;
}g[maxn*],gg[maxn*];
int head[maxn],head2[maxn];
int cnt=;
void add(int u,int v,bool val){
g[cnt].to=v;
g[cnt].nxt=head[u];
g[cnt].val=val;
head[u]=cnt++;
}
int deep=;
int dfn[maxn],low[maxn];
bool vis[maxn];
bool used[maxn];
int Stack[maxn];
bool a[maxn];
int color[maxn];
int tot=;
int tail=;
int n,m;
void tarjan(int u,int fa){
dfn[u]=++deep;
low[u]=deep;
Stack[++tail]=u;
vis[u]=;
int t=head[u];
while(t!=-){
if(g[t].to==fa){
t=g[t].nxt;
continue;
}
if(!dfn[g[t].to]){
tarjan(g[t].to,u);
low[u]=min(low[u],low[g[t].to]);
}
else{
if(vis[g[t].to]){
low[u]=min(low[u],low[g[t].to]);
}
}
t=g[t].nxt;
}
if(dfn[u]==low[u]){
tot++;
while(Stack[tail]!=u){
vis[Stack[tail]]=;
color[Stack[tail]]=tot;
tail--;
}
vis[Stack[tail]]=;
color[Stack[tail]]=tot;
tail--;
}
}
void add2(int u,int v,int val){
gg[cnt].to=v;
gg[cnt].nxt=head2[u];
gg[cnt].val=val;
head2[u]=cnt++;
}
void suodian(){
for(int i=;i<=n;i++){
int t=head[i];
while(t!=-){
if(color[i]==color[g[t].to]){
a[color[i]]+=g[t].val;
}
else if(g[t].to>i){
//cout<<i<<' '<<g[t].to<<endl;
add2(color[i],color[g[t].to],g[t].val);
add2(color[g[t].to],color[i],g[t].val);
}
t=g[t].nxt;
}
}
}
bool ans=;
void dfs2(int u,int fa,int aim,bool re){
//cout<<u<<endl;
if(u==aim){
ans+=re;
return ;
}
int t=head2[u];
while(t!=-){
if(gg[t].to!=fa){
dfs2(gg[t].to,u,aim,re+gg[t].val+a[gg[t].to]);
}
t=gg[t].nxt;
}
}
int main(){
memset(head,-,sizeof(head));
memset(head2,-,sizeof(head2));
int x,y,val;
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++){
scanf("%d%d%d",&x,&y,&val);
add(x,y,(bool)val);
add(y,x,(bool)val);
}
int s,t;
scanf("%d%d",&s,&t);
for(int i=;i<=n;i++){
if(!dfn[i]){
tarjan(i,);
}
}
cnt=;
suodian();
dfs2(color[s],,color[t],a[color[s]]);
if(ans){
cout<<"YES"<<endl;
}
else{
cout<<"NO"<<endl;
}
}

tarjan求强连通分量的更多相关文章

  1. UESTC 901 方老师抢银行 --Tarjan求强连通分量

    思路:如果出现了一个强连通分量,那么走到这个点时一定会在强连通分量里的点全部走一遍,这样才能更大.所以我们首先用Tarjan跑一遍求出所有强连通分量,然后将强连通分量缩成点(用到栈)然后就变成了一个D ...

  2. tarjan求强连通分量+缩点+割点以及一些证明

    “tarjan陪伴强联通分量 生成树完成后思路才闪光 欧拉跑过的七桥古塘 让你 心驰神往”----<膜你抄>   自从听完这首歌,我就对tarjan开始心驰神往了,不过由于之前水平不足,一 ...

  3. Tarjan求强连通分量,缩点,割点

    Tarjan算法是由美国著名计算机专家发明的,其主要特点就是可以求强连通分量和缩点·割点. 而强联通分量便是在一个图中如果有一个子图,且这个子图中所有的点都可以相互到达,这个子图便是一个强连通分量,并 ...

  4. tarjan求强连通分量+缩点+割点/割桥(点双/边双)以及一些证明

    “tarjan陪伴强联通分量 生成树完成后思路才闪光 欧拉跑过的七桥古塘 让你 心驰神往”----<膜你抄>   自从听完这首歌,我就对tarjan开始心驰神往了,不过由于之前水平不足,一 ...

  5. HDU 1827 Summer Holiday(tarjan求强连通分量+缩点构成新图+统计入度+一点贪心思)经典缩点入门题

    Summer Holiday Time Limit: 10000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  6. CCF 高速公路 tarjan求强连通分量

    问题描述 某国有n个城市,为了使得城市间的交通更便利,该国国王打算在城市之间修一些高速公路,由于经费限制,国王打算第一阶段先在部分城市之间修一些单向的高速公路. 现在,大臣们帮国王拟了一个修高速公路的 ...

  7. UVALive 4262——Trip Planning——————【Tarjan 求强连通分量个数】

    Road Networks Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit Stat ...

  8. tarjan求强连通分量(模板)

    https://www.luogu.org/problem/P2341 #include<cstdio> #include<cstring> #include<algor ...

  9. Tarjan求强连通分量、求桥和割点模板

    Tarjan 求强连通分量模板.参考博客 #include<stdio.h> #include<stack> #include<algorithm> using n ...

  10. poj 2186 tarjan求强连通分量

    蕾姐讲过的例题..玩了两天后才想起来做 貌似省赛之后确实变得好懒了...再努力两天就可以去北京玩了! 顺便借这个题记录一下求强连通分量的算法 1 只需要一次dfs 依靠stack来实现的tarjan算 ...

随机推荐

  1. 嵌入式V3s交叉编译 tslib和QT4.8.7,并使用Qt Creator编译项目

    本文主参考:http://zero.lichee.pro/%E5%BA%94%E7%94%A8/QT_index.html 环境 Ubuntu16 64位 arm-linux-gnueabihf ve ...

  2. centos 后台挂起运行python

    用Xshell连接服务器运行python文件,当关闭终端或连接断开后相应的python文件也就不会继续运行了,要达到后台挂起运行就要使用 nohup 命令了. 用法如下: # -u 表示禁止缓存,将结 ...

  3. 工控随笔_03_西门子_Step7项目打开后CPU显示问号解决方法

    我们在利用西门子的S7-300/400 PLC的编程软件Step7的时候会出现下面如图所示的问题. 在打开项目的时候,我们会在Simatic Manager里面看到CPU以及一些其他一些组件显示问号. ...

  4. mac下常用命令

    常用命令 ls 查看当前目录下的文件 cd 进入某目录 . cd - 跳转回前一目录 . cd ~ 进入当前用户个人目录 pwd 输出当前所在路径 mkdir 新建文件夹. touch 新建文件 fi ...

  5. 学习笔记《Java多线程编程实战指南》二

    2.1线程属性 属性 属性类型及用途  只读属性  注意事项 编号(id) long型,标识不同线程  是  不适合用作唯一标识 名称(name) String型,区分不同线程  否  设置名称有助于 ...

  6. MVC和WebApi的区别:

    1.mvc 和WebApi: 区别: a.MVC是建立网站的一种框架,倾向于返回用户的页面请求:webApi倾向于返回用户数据请求 b.mvc直接继承system.mvc.controller:web ...

  7. Layout-2相关代码:3列布局代码演化[一]

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  8. hive动态分区问题--分区为中文

    报错如下: Loading data to table data_da.tmp_wlw_test partition (stat_date=2017-05-11, business_type_name ...

  9. 推介一个学习JAVA的系列教程-狗鱼IT教程

    介绍一个学JAVA的零基础学习JAVA的网站,推介一个学习JAVA的系列教程-狗鱼IT教程 下面是java的系教程: 1、[java教程]Java 教程 2、[java教程]Java 简介 3、[ja ...

  10. mybatis入门篇:Mybatis高级查询

    1.ResultMap的association与collection association与collection功能类似,区别是一对一与一对多,这里以association为例. 首先说明一下需求: ...