tarjan求强连通分量
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求强连通分量的更多相关文章
- UESTC 901 方老师抢银行 --Tarjan求强连通分量
思路:如果出现了一个强连通分量,那么走到这个点时一定会在强连通分量里的点全部走一遍,这样才能更大.所以我们首先用Tarjan跑一遍求出所有强连通分量,然后将强连通分量缩成点(用到栈)然后就变成了一个D ...
- tarjan求强连通分量+缩点+割点以及一些证明
“tarjan陪伴强联通分量 生成树完成后思路才闪光 欧拉跑过的七桥古塘 让你 心驰神往”----<膜你抄> 自从听完这首歌,我就对tarjan开始心驰神往了,不过由于之前水平不足,一 ...
- Tarjan求强连通分量,缩点,割点
Tarjan算法是由美国著名计算机专家发明的,其主要特点就是可以求强连通分量和缩点·割点. 而强联通分量便是在一个图中如果有一个子图,且这个子图中所有的点都可以相互到达,这个子图便是一个强连通分量,并 ...
- tarjan求强连通分量+缩点+割点/割桥(点双/边双)以及一些证明
“tarjan陪伴强联通分量 生成树完成后思路才闪光 欧拉跑过的七桥古塘 让你 心驰神往”----<膜你抄> 自从听完这首歌,我就对tarjan开始心驰神往了,不过由于之前水平不足,一 ...
- HDU 1827 Summer Holiday(tarjan求强连通分量+缩点构成新图+统计入度+一点贪心思)经典缩点入门题
Summer Holiday Time Limit: 10000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- CCF 高速公路 tarjan求强连通分量
问题描述 某国有n个城市,为了使得城市间的交通更便利,该国国王打算在城市之间修一些高速公路,由于经费限制,国王打算第一阶段先在部分城市之间修一些单向的高速公路. 现在,大臣们帮国王拟了一个修高速公路的 ...
- UVALive 4262——Trip Planning——————【Tarjan 求强连通分量个数】
Road Networks Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Submit Stat ...
- tarjan求强连通分量(模板)
https://www.luogu.org/problem/P2341 #include<cstdio> #include<cstring> #include<algor ...
- Tarjan求强连通分量、求桥和割点模板
Tarjan 求强连通分量模板.参考博客 #include<stdio.h> #include<stack> #include<algorithm> using n ...
- poj 2186 tarjan求强连通分量
蕾姐讲过的例题..玩了两天后才想起来做 貌似省赛之后确实变得好懒了...再努力两天就可以去北京玩了! 顺便借这个题记录一下求强连通分量的算法 1 只需要一次dfs 依靠stack来实现的tarjan算 ...
随机推荐
- Orchard-官方文档翻译1 Orchard的工作方式
开发一个CMS(内容管理系统)程序,与开发一个普通的应用程序很大情况下是不同的,CMS程序更像是一个应用程序的管理器系统.当我们在设计这个系统的时候,第一考虑的是它的扩展性,这是一个非常有挑战的开放式 ...
- Axure RP 7 8
Axure RP 7.0 用户名:axureuser 序列号:8wFfIX7a8hHq6yAy6T8zCz5R0NBKeVxo9IKu+kgKh79FL6IyPD6lK7G6+tqEV4LG Axur ...
- Linux基础上
文件操作 ...
- centos 7刚安装后无法联网解决
从6版本到7版本后, 7版本默认会关闭网卡 ,并且ifconfig 命令也换了 ip 命令来代替, 在这记录一下 ,希望 新人发现. 不是源的问题, 是压根没开网卡... 下面是写给萌新的: 先看一下 ...
- WinForm控件--DotNetBar--SuperGridControl
//SuperGridControl控件初始化 private void ResetLayout(SuperGridControl SGC) { GridPanel panel = SGC.Prima ...
- 自定义panel实现,并实现item更改和移除动画。
原地址:https://www.cnblogs.com/yk250/p/10043694.html 无图无真相: 1,重写panel类(模拟实现一个竖直方向排列的panel,相当于默认的StackP ...
- Oracle 归档日志文件
今天数据群有人反应网站不能正常打开,经检查Oracle数据库远程连不上,提示信息:ORA-00257: archiver error. Connect internal only, until f ...
- Linux高级指令
一.hostname指令 作用:操作服务器的主机名(读取,设置) #hostname 作用:表示输出完整的主机名 #hostname -f 作用:表示输出当前主机名中的FQDN(权限定域名 ...
- Python常用高级函数
一 .匿名函数 有些时候,我们不需要显式的定义函数,可以使用匿名函数临时快速定义函数. lambda x: x * x 关键字lambda表示匿名函数,冒号前面的x表示函数的参数,多个参数用','隔开 ...
- Linux java进程无故被kill
这两天,演示环境的java应用无端端就被停止了.在这里记录一下原因和排查过程: 发现应用挂掉以后,第一时间登陆centos,发现进程没有了.于是重新启动应用. 但是启动不起来,去看业务日志,没有找到任 ...