L - 方老师和农场

Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others)
Submit Status

方老师重新开了一家农场,农场一共有N个节点和M条双向边,但是有一个很大的问题就是有比如一个农场A到达农场B只有一条路径,问至少添加多少条边使得任意两个农场之间的路径多于一条。

Input

  • 多组数据,EOF结束。
  • 第1行:N和M。
  • 第2到第M+1行:每一行2个数Ui和Vi,表示Ui到Vi之间有一条边。

Output

一行一个数表示至少需要添加多少条边。

Sample input and output

Sample Input Sample Output
7 7
1 2
2 3
3 4
2 5
4 5
5 6
5 7
2

Hint

N≤100000,M≤100000

解题思路:

我们先考虑原图连通的情况

首先跑一遍图,求出所有的桥,之后跑出边双连通分量数目.

将边双连通分量看成一个点.

之后我们考虑整个图,必然成了一棵树.

证明:

假设将边双连通分量看成一个点后图不是树,必然存在两个儿子之间连有边,这样就构成了边双连通,显然不合法,故命题正确.

<B,C>之间不可能有边,否则构成了边双连通.

之后我们将问题转换为了树上至少连多少条边,使得树上任意两点的路径条数多于两条?

这样问题就很容易解了.

设树上的叶子有 N 个

If N ∈ (2 * k ) , ans = N / 2;

Else ans = ( N + 1 ) / 2

综合下得 ans = (N + 1 ) / 2;

为什么这样是对的呢?,我们将树上非叶的结点看成一个大圆圈,之后叶子,两两配对(找不到就自己和自己配),配对的顺序是第 x 个,和第 n – x + 1个,如图:

之后我们考虑,若原图不连通,如何求解?

还是看成大圆圈加几个根,把所有的叶子数加起来当成 N 就可以了.

这里有点要注意,我们给一旦连了一条边,其实我们就等于给大圆圈连了一条边了

<夜深了,就不证明了>

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <vector>
#include <set>
#define pb push_back //#define localtest using namespace std;
const int maxn = 1e5 + ;
int n,m,new_time[maxn],low[maxn],T,tot,degree[maxn],number[maxn];
bool use[maxn]; typedef pair<int,int> Etype;
set<Etype>spj; typedef struct Edge
{
int v,isbridge;
Edge(const int &v)
{
this->v = v;
isbridge = ;
}
}; vector<Edge>E[maxn]; int tarjan_dfs(int cur,int pre)
{
new_time[cur] = low[cur] = T++;
for(int i = ; i < E[cur].size() ; ++ i)
{
int nextnode = E[cur][i].v;
if (!new_time[nextnode]) //树边
{
int lowv = tarjan_dfs(nextnode,cur);
if (lowv > new_time[cur])
{
E[cur][i].isbridge = ;
#ifdef localtest
cout << cur << " - " << nextnode << " is a bridge " << endl;
#endif
use[cur] = true , use[nextnode] = true;
}
low[cur] = min(low[cur],lowv); // updata
}
else if(new_time[nextnode] < new_time[cur] && nextnode != pre) //反向边
low[cur] = min(low[cur],low[nextnode]);
}
return low[cur];
} int main(int argc,char *argv[])
{
while(~scanf("%d%d",&n,&m))
{
spj.clear();
for(int i = ; i <= m ; ++ i)
{
int u,v;
scanf("%d%d",&u,&v);
if (u > v)
swap(u,v);
Etype temp(u,v);
if (spj.count(temp))
continue;
else
spj.insert(temp);
E[u].pb(Edge(v)) , E[v].pb(Edge(u));
}
memset(new_time,,sizeof(new_time));
memset(number,,sizeof(number));
memset(use,false,sizeof(use));
memset(degree,,sizeof(degree));
T = ;
for(int i = ; i <= n ; ++ i)
if (!new_time[i])
tarjan_dfs(i,); //跑割桥
for(int i = ; i <= n ; ++ i)
{
for(int j = ; j < E[i].size() ; ++ j)
{
int nextnode = E[i][j].v;
if (low[i] != low[nextnode]) //缩点
{
degree[low[i]] ++ ;
degree[low[nextnode]] ++ ;
}
}
}
int leaf = ;
for(int i = ; i <= n ; ++ i)
if (degree[i] == )
leaf++;
printf("%d\n",(leaf+)/);
for(int i = ; i <= n ; ++ i)
E[i].clear();
}
return ;
}

UESTC_方老师和农场 2015 UESTC Training for Graph Theory<Problem L>的更多相关文章

  1. UESTC_邱老师的脑残粉 2015 UESTC Training for Graph Theory<Problem D>

    D - 邱老师的脑残粉 Time Limit: 12000/4000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Sub ...

  2. UESTC_小panpan学图论 2015 UESTC Training for Graph Theory<Problem J>

    J - 小panpan学图论 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) S ...

  3. UESTC_韩爷的情书 2015 UESTC Training for Graph Theory<Problem H>

    H - 韩爷的情书 Time Limit: 6000/2000MS (Java/Others)     Memory Limit: 262144/262144KB (Java/Others) Subm ...

  4. UESTC_秋实大哥带我飞 2015 UESTC Training for Graph Theory<Problem B>

    B - 秋实大哥带我飞 Time Limit: 300/100MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit ...

  5. UESTC_邱老师选妹子 2015 UESTC Training for Dynamic Programming<Problem H>

    H - 邱老师选妹子 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  6. UESTC_邱老师玩游戏 2015 UESTC Training for Dynamic Programming<Problem G>

    G - 邱老师玩游戏 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  7. UESTC_邱老师看电影 2015 UESTC Training for Dynamic Programming<Problem F>

    F - 邱老师看电影 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  8. UESTC_王之盛宴 2015 UESTC Training for Graph Theory<Problem K>

    K - 王之盛宴 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit  ...

  9. UESTC_排名表 2015 UESTC Training for Graph Theory<Problem I>

    I - 排名表 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit S ...

随机推荐

  1. usaco5.5-Hidden Passwords

    最小表示法,感觉可以做成个模板,第一次RE是因为字符串长度变2倍了而我把数组开小了 Executing...   Test 1: TEST OK [0.008 secs, 3760 KB]   Tes ...

  2. 关于cvAdsDiffS的那些事

    cvAbsDiffS 计算数组元素与数量之间差的绝对值 void cvAbsDiffS( const CvArr* src, CvArr* dst, CvScalar value ); #define ...

  3. mybatis学习笔记第一讲

    第一步:先配置mybatis配置 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE confi ...

  4. hibernate错题解析

    01 Hibernate错题分析   解析: 此题目考查的是对Hibernate中交叉连接的理解.HQL支持SQL风格的交叉连接查询,交叉连接适用于两个类之间没有定义任何关联时.在where字句中,通 ...

  5. 斐波那契数列 Php练手

    数列从第三项开始,每一项都等于前两项之和. F0=0,F1=1,Fn=F(n-1)+F(n-2) 递归版和非递归版. <?php function fib($n){ $array = array ...

  6. jQuery的ajax jsonp跨域请求

    了解:ajax.json.jsonp.“跨域”的关系 要弄清楚以上ajax.json.jsonp概念的关系,我觉得弄清楚ajax是“干什么的”,“怎么实现的”,“有什么问题”,“如果解决存在的问题”等 ...

  7. Test failed.尝试加载Oracle客户端库时引发BadImageFormatException

    CodeSmith6.5不像前几个版本,需要用户手动添加oracle驱动,内部已经集成了oracle的驱动. 网上遇到很多win7 64位机子使用CodeSmith连接oracle的时候出现错误如下:

  8. HTML与CSS入门——第十一章  在网页中使用图像

    知识点: 1.在网页上放置图像的方法 2.用文本描述图像的方法 3.指定图像高度和宽度的方法 4.对齐图像的方法 5.将图像转换为俩接的方法 6.使用背景图像的方法 7.使用图像映射的方法 11.1 ...

  9. SuperSocket学习笔记(一)

    这是根据我自己学习的经历整理出来的,如有不对之处,还请多多指教! SuperSocket源码下载 SuperSocket文档 安装并启动Telnet 学习方法: QuickStrart + 文档 参考 ...

  10. 《第一行代码》学习笔记21-Git

    Git(1) 1.Git是一个开源的分布式版本控制工具,其开发者是Linux操作系统的作者Linus Torvalds. 2.仓库(Repository)是用于保存版本管理所需要信息的地方,所有本地提 ...