UESTC_方老师和农场 2015 UESTC Training for Graph Theory<Problem L>
L - 方老师和农场
Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others)
方老师重新开了一家农场,农场一共有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 |
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>的更多相关文章
- UESTC_邱老师的脑残粉 2015 UESTC Training for Graph Theory<Problem D>
D - 邱老师的脑残粉 Time Limit: 12000/4000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Sub ...
- 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 ...
- UESTC_韩爷的情书 2015 UESTC Training for Graph Theory<Problem H>
H - 韩爷的情书 Time Limit: 6000/2000MS (Java/Others) Memory Limit: 262144/262144KB (Java/Others) Subm ...
- UESTC_秋实大哥带我飞 2015 UESTC Training for Graph Theory<Problem B>
B - 秋实大哥带我飞 Time Limit: 300/100MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
- UESTC_邱老师选妹子 2015 UESTC Training for Dynamic Programming<Problem H>
H - 邱老师选妹子 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- UESTC_邱老师玩游戏 2015 UESTC Training for Dynamic Programming<Problem G>
G - 邱老师玩游戏 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- UESTC_邱老师看电影 2015 UESTC Training for Dynamic Programming<Problem F>
F - 邱老师看电影 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- UESTC_王之盛宴 2015 UESTC Training for Graph Theory<Problem K>
K - 王之盛宴 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
- UESTC_排名表 2015 UESTC Training for Graph Theory<Problem I>
I - 排名表 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit S ...
随机推荐
- 教程:30分钟学会Adobe Premiere
原文地址:http://tieba.baidu.com/p/2785313831 视频教程地址
- HDU4893--Wow! Such Sequence! (线段树 延迟标记)
Wow! Such Sequence! Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Oth ...
- 关于ognl.OgnlException: target is null for setProperty(null的解决方案
在跑struts2的时候有时候会出现上面的错,特别是新手, 这种情况是在struts2高级的POJO访问时候出现的s 警告: Error setting expression 'user.passwo ...
- shell脚本一条命令直接发送http请求(xjl456852原创)
我们知道nc命令是一个网络工具.可以连接tcp/udp.也能模拟发送http请求. 现在介绍通过shell脚本,一条命令直接发送http请求. 命令如下,可以对下面的地址等信息自行修改: #!/bin ...
- NetAnalyzer笔记 之 七 NetAnalyzer2016使用方法(1)
[创建时间:2016-04-17 14:47:00] NetAnalyzer下载地址 距离新本的NetAnalyzer已经发布一段时间了,因为比较忙期间只出了一个视频教程,一直没有来的急写文档,今天就 ...
- hdu1015(Safecracker )
Problem Description === Op tech briefing, 2002/11/02 06:42 CST === "The item is locked in a Kle ...
- Oracle SQL ANY和ALL语句
Oracle的嵌套子查询可以使用Some,Any和All对子查询中返回的多行结果进行处理. Some表示满足其中一个的含义,是用or串起来的比较从句. 例如:SELECT * FROM emp WHE ...
- struts 标签引用出错
几句句话概括 1.检查 web.xml 出现错误自己改 配置后filter jsp-config 2.检查 tld 目录下的东西 是否缺少 3. 将包复制到web的lib目录下后 之后 b ...
- C#中子窗体获取父窗体中控件的内容
今天在做一个联系人管理的C#设计时,遇到了这个问题,我需要将父窗体中的textBox中的值传到子窗体并进行数据库查询操作,我用了new 父窗体().textBox.text;来进行值传递,然而并无卵用 ...
- Win 7 通过事件管理器查看计算机开机关机时间
控制面板-管理工具-事件查看器 视图中开机来源:Kernel-General 事件ID:13 关机来源:Kernel-General 事件ID:12