//  给你一个有向图,问你最少加几条边能使得该图强连通
#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <utility>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
using namespace std;
#define max(x,y) x>=y?x:y
#define lowbit(x) x&(-x)
typedef long long ll;
const int N=;
int n,m;
int head[N],low[N],num[N];
int in[N],out[N],be[N];
int ans,cnt,ans1,ans2;
int index;
bool vis[N];
struct Edge
{
int from,to,nex;
}e[N*];
stack<int>s;
void init()
{
memset(head,-,sizeof(head));
memset(num,-,sizeof(num));
memset(vis,,sizeof(vis));
memset(low,,sizeof(low));
memset(in,,sizeof(in));
memset(out,,sizeof(out));
cnt=index=;
}
void add(int u,int v)
{
e[cnt].from=u;
e[cnt].to=v;
e[cnt].nex=head[u];
head[u]=cnt++;
}
void tarjan(int u)
{
low[u]=num[u]=++index;
vis[u]=;
s.push(u);
for (int i=head[u];i!=-;i=e[i].nex)
{
int v=e[i].to;
if(num[v]==-)
{
tarjan(v);
low[u]=min(low[u],low[v]);
}
else if(vis[v])
{
low[u]=min(low[u],num[v]);
}
}
if(num[u]==low[u])
{
int x;
ans++;
do{
x=s.top();
s.pop();
vis[x]=;
be[x]=ans;
}while(x!=u);
}
}
int main()
{
while(~scanf("%d %d",&n,&m))
{
init();
ans=;
int a,b;
for (int i=;i<m;i++)
{
scanf("%d %d",&a,&b);
add(a,b); }
for (int i=;i<=n;i++)
{
if(num[i]==-)
{
tarjan(i);
}
}
for (int i=;i<cnt;i++)
{
int a=e[i].from;
int b=e[i].to;
if(be[a]!=be[b])
{
in[be[b]]++;
out[be[a]]++;
}
}
ans1=ans2=;
for (int i=;i<=ans;i++)//ans 从1开始。ans为原图强联通分量的个数、
{
if(!in[i])
{
ans1++;
}
if(!out[i])
{
ans2++;
}
}
printf("%d\n",ans==?:max(ans1,ans2));
}
return ;
} /* 3 2
1 2
2 3 有3个联通快 */

hdu 3836 tarjain 求强连通分量个数的更多相关文章

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

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

  2. Electricity POJ - 2117 + SPF POJ - 1523 去除割点后求强连通分量个数问题

    Electricity POJ - 2117 题目描述 Blackouts and Dark Nights (also known as ACM++) is a company that provid ...

  3. HDU - 3836 Equivalent Sets (强连通分量+DAG)

    题目大意:给出N个点,M条边.要求你加入最少的边,使得这个图变成强连通分量 解题思路:先找出全部的强连通分量和桥,将强连通分量缩点.桥作为连线,就形成了DAG了 这题被坑了.用了G++交的,结果一直R ...

  4. HDU1269迷宫城堡(裸Tarjan有向图求强连通分量个数)

    迷宫城堡Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...

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

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

  6. 求强连通分量模板(tarjan算法)

    关于如何求强连通分量的知识请戳 https://www.byvoid.com/blog/scc-tarjan/ void DFS(int x) { dfn[x]=lowlink[x]=++dfn_cl ...

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

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

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

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

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

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

随机推荐

  1. 51NOD 区间的价值 V2

    http://www.51nod.com/contest/problem.html#!problemId=1674 因为题目要求的只是& 和 | 这两个运算.而这两个运算产生的值是有限的. & ...

  2. 《四 spring源码》手写springioc框架

    手写SpringIOCXML版本 /** * 手写Spring专题 XML方式注入bean * * * */ public class ClassPathXmlApplicationContext { ...

  3. Ionic开发-搭建开发环境

    1安装node.js 2安装ionic & cordova: 命令行输入:npm install –g cordova ionic 注:-g表示全局安装,也可以进入指定的目录安装,但这里推荐全 ...

  4. WPF 模拟Button按钮事件触发

    this.Submit.AddHandler(Button.ClickEvent, new RoutedEventHandler(this.Submit_Click)); //这种是无效的方法 thi ...

  5. 关于 SQL Server Reporting Services 匿名登录的解决方案

    每次访问报表都需要windows验证,这样的报表给客户确实很说不过去. SSRS 可以匿名登录的设定步骤: 环境: 开发工具:SQL Server Business Intelligence Deve ...

  6. IDEA对比文件

    和另一个文件对比:右击文件,选择另一个文件 和剪切板的内容对比:右击代码区域

  7. AJPFX关于ArrayList集合容器的操作

    1.创建     ArrayList<Egg> myList=new ArrayList<Egg>(); //<Egg>代表创建出Egg类型的List,新的Arra ...

  8. dubbo注解

    如果还不了解Dubbo是什么或者不知道怎么搭建的可以先看一下我的上一篇文章. 首先我先来讲下提供者(也就是服务端)的配置,先上配置文件代码: <?xml version="1.0&qu ...

  9. guacamole 0.9.13安装与配置

    以下命令很多都需要管理权限,建议使用管理员账号执行,遇到问题可以留言. Guacamole官网文档介绍翻译:http://www.cnblogs.com/ji-yun/p/5657709.html 1 ...

  10. css继承性

    不可继承的:display.margin.border.padding.background.height.min-height.max- height.width.min-width.max-wid ...