[kuangbin带你飞]专题九 连通图C - Critical Links UVA - 796
这道题就是要求桥的个数。
那么桥相应的也有判定的定理:
在和u相邻的节点中,存在一个节点是最小的时间戳都比
            当前u的访问次序要大,也就是说这个点是只能通过果u到达,那么
            他们之间相邻的边就是的桥
#include<iostream>
#include<string.h>
#include<algorithm>
#include<stdio.h>
using namespace std;
const int SIZE = ;
struct node{
int u,v;
}brige[SIZE];
int head[SIZE],ver[SIZE*],Next[SIZE*];
int dfn[SIZE],low[SIZE],n,m,tot,num,cnt;
void add(int x,int y){
ver[++tot]=y,Next[tot]=head[x],head[x]=tot;
}
void tarjan(int u,int pre){
dfn[u]=low[u]=++num;
for (int i=head[u];i;i=Next[i]){
int v=ver[i];
if (v==pre)continue;
if (!dfn[v]){
tarjan(v,u);
low[u]=min(low[u],low[v]);
if (low[v]>dfn[u]){
/*
在和u相邻的节点中,存在一个节点是最小的时间戳都比
当前u的访问次序要大,也就是说这个点是只能通过果u到达,那么
他们之间相邻的边就是的桥
*/
cnt++;
brige[cnt].u=u;
brige[cnt].v=v;
if (brige[cnt].u>brige[cnt].v){
swap(brige[cnt].u,brige[cnt].v);
}
}
}
else if (low[u]>dfn[v])
low[u]=min(low[u],dfn[v]);
}
}
void init(){
memset(brige,,sizeof(brige));
memset(low,,sizeof(low));
memset(ver,,sizeof(ver));
memset(dfn,,sizeof(dfn));
memset(Next,,sizeof(Next));
memset(head,,sizeof(head));
cnt=;
num=;
tot=;
}
bool cmp(node a,node b){
if (a.u==b.u)return a.v<b.v;
return a.u<b.u;
}
int main(){
int id,tmp,nx;
while(~scanf("%d",&n)){
if (n==){
printf("0 critical links\n\n");
continue;
}
init();
for(int i=;i<=n;i++){
scanf("%d",&id);
id++;
getchar();
getchar();
scanf("%d",&tmp);
getchar();
for (int j=;j<=tmp;j++){
scanf("%d",&nx);
nx++;
add(id,nx);
add(nx,id);
}
}
for (int i=;i<=n;i++){
if(!dfn[i])tarjan(i,i);
}
printf("%d critical links\n",cnt);
sort(brige+,brige++cnt,cmp);
for (int i=;i<=cnt;i++){
printf("%d - %d\n",brige[i].u-,brige[i].v-);
}
printf("\n"); }
return ;
}
/*
3 critical links
0 - 1
3 - 4
6 - 7 */
[kuangbin带你飞]专题九 连通图C - Critical Links UVA - 796的更多相关文章
- [kuangbin带你飞]专题九 连通图
		
ID Origin Title 76 / 163 Problem A POJ 1236 Network of Schools 59 / 177 Problem B UVA 315 Ne ...
 - [kuangbin带你飞]专题九 连通图E  POJ 3177	Redundant Paths
		
这个题最开始我想的是,直接缩点求双连通分量,连接这些双联通分量不就行了吗? 但是其实是不对的,双连通内部双联通,我们如果任意的连接一条边在这些双联通分量之间,他们之间有没有桥其实并不知道. 我应该是求 ...
 - [kuangbin带你飞]专题九 连通图D - Network POJ - 3694
		
这道题其实也非常简单,只是在求割边及其个数的情况下,每次往里面加入新的边,并再次计算割边的个数. 我们用tarjan可以求出原图的桥以及个数,当然我们不能暴力加边,然后求解,那么如何求呢??? 其实非 ...
 - [kuangbin带你飞]专题九 连通图B - Network UVA - 315
		
判断割点的性质: 如果点y满足 low[y]>=dfn[x] 且不是根节点 或者是根节点,满足上述式子的有两个及其以上. 就是割点 如果是起点,那么至少需要两个子节点满足上述条件,因为它是根节点 ...
 - 给自己的小练习19-[kuangbin带你飞]专题九连通图
		
没有写题解.补一波 Network of Schools 问题1:求有向图中入度为0的点个数 问题2:使得整个图变成一个联通分量 问题1直接缩点统计 问题2=max(入度为0的点,出度为0的点),注意 ...
 - [kuangbin带你飞]专题1-23题目清单总结
		
[kuangbin带你飞]专题1-23 专题一 简单搜索 POJ 1321 棋盘问题POJ 2251 Dungeon MasterPOJ 3278 Catch That CowPOJ 3279 Fli ...
 - 【算法系列学习三】[kuangbin带你飞]专题二 搜索进阶 之 A-Eight 反向bfs打表和康拓展开
		
[kuangbin带你飞]专题二 搜索进阶 之 A-Eight 这是一道经典的八数码问题.首先,简单介绍一下八数码问题: 八数码问题也称为九宫问题.在3×3的棋盘,摆有八个棋子,每个棋子上标有1至8的 ...
 - [kuangbin带你飞]专题十 匹配问题
		
A-L 二分匹配 M-O 二分图多重匹配 P-Q 二分图最大权匹配 R-S 一般图匹配带花树 模板请自己找 ID Origin Title 61 / 72 Problem A HD ...
 - [kuangbin带你飞]专题十 匹配问题 一般图匹配
		
过去做的都是二分图匹配 即 同一个集合里的点 互相不联通 但是如果延伸到一般图上去 求一个一般图的最大匹配 就要用带花树来解决 带花树模板 用来处理一个无向图上的最大匹配 看了一会还是不懂 抄了一遍 ...
 
随机推荐
- linux环境变量设置命令
			
1echo $ <变量名> //显示某个环境变量 2env // environment (环境) 的简写,列出来所有的环境变量 3set //显示所有本地定义的Shell ...
 - Redis 复制、Sentinel的搭建和原理说明(转)
			
Redis 复制.Sentinel的搭建和原理说明 转自:http://www.cnblogs.com/zhoujinyi/p/5570024.html. 背景: Redis-Sentinel是Re ...
 - mybatis的第一个程序
			
程序结构图: 表结构: 创表sql: CREATE TABLE `users` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varch ...
 - PHP相关
			
PHP简介 PHP超文本预处理器.是嵌入HTML文件中的服务器端脚本程序.换句话:PHP只能运行在服务器上. 一个HTML文件中,可以包含的代码:HTML代码.CSS代码.JS代码.PHP代码等. P ...
 - 快速排序的一种实现(Mark Allen 数据结构与算法 c语言版)
			
之前关于快速排序一直比较模糊,网上有几种常见写法: 方法一: void quickSort(int s[], int l, int r) { if (l< r) { int i = l, j = ...
 - 手把手教你如何玩转消息中间件(ActiveMQ)  https://blog.csdn.net/cs_hnu_scw/article/details/81040834
			
#情景引入小白:起床起床起床起床....快起床~我:怎么了又,大惊小怪,吓到我了.小白:我有事有事想找你,十万火急呢~~我:你能有什么事?反正我不信..那你说说看~~小白:就是我有两个小表弟,叫大白和 ...
 - 【linux配置】VMware安装Redhat6.5
			
VMware安装Redhat6.5 VMware安装Redhat6.5安装之前需要一些准备工作,首先,电脑上需要安装VMware(这个是废话),其次就是需要Redhat6.5的镜像文件(现在貌似都出R ...
 - 软件测试 → 第二章 基础-> 软件缺陷与缺陷管理
			
一.缺陷定义与分类 1.1.软件缺陷 定义:在软件工程整个生命周期中任何背离需求.无法正确完成用户所要求的功能的问题,包括存在于组件.设备.或系统软件中因异常条件不支持而导致系统失败等都属于缺陷. 从 ...
 - python 正则表达式语法
 - QT UI 线程为什么卡死?
			
我的工程是由三个线程处理不同任务构成的,其中UI用于显示,还有数据处理和数据接收发送线程. 在运行的过程中发现由于数据处理线程不及时,超过了设定的100ms,导致UI卡死,几个周期后又恢复,接着又卡死 ...