hdu 3352 求边双联通分量模板题(容器)
/*这道题是没有重边的,求加几条边构成双联通,求边联通分量,先求出桥然后缩点,成一个棵树
找叶子节点的个数*/
#include<stdio.h>
#include<string.h>
#define N 1100
int top[N],ma[N][N],dfn[N],low[N],index,f[N][N],n;
int Min(int a,int b) {
return a>b?b:a;
}
void tarjan(int u,int pre) {//
dfn[u]=low[u]=++index;
int i;
for(i=0;i<top[u];i++) {
int v=ma[u][i];
if(v==pre)continue;
if(!dfn[v]) {
tarjan(v,u);
low[u]=Min(low[u],low[v]);//
if(low[v]>dfn[u])//标记桥
f[u][v]=f[v][u]=1;
}
else
low[u]=Min(low[u],dfn[v]);
}
}
int cnt,c[N];
void dfs(int u,int fa) {//缩点
int i;
c[u]=cnt;//不能放到循环里面,
for(i=0;i<top[u];i++) {
int v=ma[u][i];
if(!f[u][v]&&!c[v]&&v!=fa)//桥不能走,不能回头路,没有被缩过
dfs(v,u);
}
return ;
}
int degree[N];
int slove() {
int i,j,b;
cnt=1;
memset(c,0,sizeof(c));
for(i=1;i<=n;i++)//缩点
if(!c[i]) {
dfs(i,-1);
cnt++;
}
memset(degree,0,sizeof(degree));
for(i=1;i<=n;i++)
for(j=0;j<top[i];j++){
b=ma[i][j];
if(c[i]!=c[b]) {//所有边中
degree[c[i]]++;
degree[c[b]]++;//记录度数
}
}
int leave=0;
for(i=1;i<cnt;i++) {//度数为一的叶子节点,因为为双向边
if(degree[i]==2)
leave++;
}
return (leave+1)/2;
}
int main() {
int m,i,a,b,ans;
while(scanf("%d%d",&n,&m)!=EOF) {
memset(top,0,sizeof(top));
memset(dfn,0,sizeof(dfn));
memset(low,0,sizeof(low));
memset(f,0,sizeof(f));
index=0;
while(m--){
scanf("%d%d",&a,&b);
ma[a][top[a]++]=b;//容器
ma[b][top[b]++]=a;
}
for(i=1;i<=n;i++)
if(!dfn[i])
tarjan(i,-1);
ans=slove();
printf("%d\n",ans);
}
return 0;
}
hdu 3352 求边双联通分量模板题(容器)的更多相关文章
- poj 3177&&3352 求边双联通分量,先求桥,然后求分量( 临界表代码)
/*这道题是没有重边的,求加几条边构成双联通,求边联通分量,先求出桥然后缩点,成一个棵树 找叶子节点的个数*/ #include<stdio.h>//用容器写在3177这个题上会超内存,但 ...
- POJ 2942 Knights of the Round Table 补图+tarjan求点双联通分量+二分图染色+debug
题面还好,就不描述了 重点说题解: 由于仇恨关系不好处理,所以可以搞补图存不仇恨关系, 如果一个桌子上面的人能坐到一起,显然他们满足能构成一个环 所以跑点双联通分量 求点双联通分量我用的是向栈中pus ...
- 【UVA10972】RevolC FaeLoN (求边双联通分量)
题意: 给你一个无向图,要求把所有无向边改成有向边,并且添加最少的有向边,使得新的有向图强联通. 分析: 这题的解法还是很好想的.先用边双联通分量缩点,然后找新图中入度为0和为1的点,入度为0则ans ...
- 洛谷P2860 [USACO06JAN]冗余路径Redundant Paths(tarjan求边双联通分量)
题目描述 In order to get from one of the F (1 <= F <= 5,000) grazing fields (which are numbered 1. ...
- POJ3177 & 求边双联通分量
题意: 给一张无向图,求加多少边使原图任意两点边双联通. SOL: 一个不会写边双点双强联通的傻逼. 一个结论:把一棵树变成满足条件的图需要加的边使入度为1的点数+1除以2.------>就是树 ...
- POJ 3352 Road Construction 双联通分量 难度:1
http://poj.org/problem?id=3352 有重边的话重边就不被包含在双连通里了 割点不一定连着割边,因为这个图不一定是点连通,所以可能出现反而多增加了双连通分量数的可能 必须要用割 ...
- cf999E (强联通分量模板题)
给出n个点m条边的有向图,问至少添加多少条边使得任何点都可以从s点出发可达 #include<bits/stdc++.h> #define forn(i, n) for (int i = ...
- ARC062 - F. Painting Graphs with AtCoDeer (Polya+点双联通分量)
似乎好久都没写博客了....赶快来补一篇 题意 给你一个 \(n\) 个点 , 没有重边和自环的图 . 有 \(m\) 条边 , 每条边可以染 \(1 \to k\) 中的一种颜色 . 对于任意一个简 ...
- [J]computer network tarjan边双联通分量+树的直径
https://odzkskevi.qnssl.com/b660f16d70db1969261cd8b11235ec99?v=1537580031 [2012-2013 ACM Central Reg ...
随机推荐
- WPF学习笔记——没有前途的WPF
看上去,WPF比silverlight有前途一点.毕竟,微软还没有宣布,WPF停止更新. 但我怀疑,不久的将来,WPF也会步其子集silverlight的后尘,要么不再出后续版本,要么向HTML5 + ...
- 【Ubuntu】基本操作 (条目=11)
定义 NAME 为要操作的对象名 定义 DIR 为文件所在的绝对路径 所有操作默认在普通用户下进行 所有软件包默认是指Debian包(deb包) 1.查看进程 top 2.强制结束进程 PID由top ...
- Base Class Doesn't Contain Parameterless Constructor?
http://stackoverflow.com/questions/7689742/base-class-doesnt-contain-parameterless-constructor #regi ...
- EOJ 3384 食物链
动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 C,C 吃 A. 现有 N 个动物,以 1-N 编号.每个动物都是 A,B,C 中的一种,但是我们并不知道它到 ...
- 杂项:Web API
ylbtech-杂项:Web API 今天的web计算平台包含了广泛的功能,其中的大部分均可以通过API(应用程序编程接口)访问. 从简单的社会书签服务del.icio.us,到复杂得多的amazon ...
- 实现泛型IEnumerable接口
用C#实现一个类的IEnumerable接口时有两种方法:1)实现非泛型IEnumerable接口:2)实现泛型IEnumerable(T)接口.如果采用方法1,当集合元素T是值类型时,将涉及到巨多的 ...
- E20170813-ts
explicitly adv. 明白地,明确地;
- Appium + python - input操作实例
import osimport time as t adb = 'adb shell input tap 400 500'os.system(adb) t.sleep(5) class keyeven ...
- selenium3 + python - js处理readonly属性
前言 日历控件是web网站上经常会遇到的一个场景,有些输入框是可以直接输入日期的,有些不能,以我们经常抢票的12306网站为例,详细讲解如何解决日历控件为readonly属性的问题. 基本思路:先用j ...
- 使用IDEA 搭建一个SpringBoot + Hibernate + Gradle
---恢复内容开始--- 打开IDEA创建一个新项目: 第一步: 第二步: 第三步: 最后一步: 如果下载的时候时间太久.可以找到build.gradle文件,添加以下代码.如下图 maven{ ur ...