F - Warm up - hdu 4612(缩点+求树的直径)
#pragma comment(linker, "/STACK:102400000,102400000")
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
using namespace std; const int MAXN = 2e5+; struct Edge{int v, vis, next;}e1[MAXN*], e2[MAXN*];
int Head1[MAXN], Head2[MAXN], cnt[], fa[MAXN];
void AddEdge(Edge e[], int Head[], int u, int v, int k)
{
e[ cnt[k] ].v = v;
e[ cnt[k] ].vis = ;
e[ cnt[k] ].next = Head[u];
Head[u] = cnt[k]++;
} struct node{int u, step;};
node BFS(node s, int k)
{
queue<node> Q;
Q.push(s); while(Q.size())
{
s = Q.front();Q.pop(); for(int j=Head2[s.u]; j!=-; j=e2[j].next)
{
node q = s;
q.u = e2[j].v; if(e2[j].vis != k)
{
e2[j].vis = e2[j^].vis = k;
q.step++;
Q.push(q);
}
} } return s;
} int dfn[MAXN], low[MAXN], Index;
int belong[MAXN], bnt;
int Stack[MAXN], top; void InIt(int N)
{
cnt[] = cnt[] = Index = bnt = top = ;
for(int i=; i<=N; i++)
{
Head1[i] = Head2[i] = -;
dfn[i] = ;
fa[i] = ;
}
}
void Tarjan(int u)
{
int v; low[u] = dfn[u] = ++Index;
Stack[++top] = u; for(int j=Head1[u]; j!=-; j=e1[j].next)
{
v = e1[j].v;
if(e1[j].vis == false)
{
e1[j].vis = e1[j^].vis = true;
if( !dfn[v] )
{
Tarjan(v);
low[u] = min(low[u], low[v]);
}
else
low[u] = min(low[u], dfn[v]);
}
} if(low[u] == dfn[u])
{
++bnt;
do
{
v = Stack[top--];
belong[v] = bnt;
}
while(u != v);
}
}
int main()
{
int N, M; while(scanf("%d%d", &N, &M), N+M)
{
int i, j, u, v; InIt(N); while(M--)
{
scanf("%d%d", &u, &v);
AddEdge(e1, Head1, u, v, );
AddEdge(e1, Head1, v, u, );
} Tarjan(); for(i=; i<=N; i++)
for(j=Head1[i]; j!=-; j=e1[j].next)
{
v = e1[j].v;
u = belong[i], v = belong[v];
if(u > v && fa[v] != u)
{
fa[v] = u;
AddEdge(e2, Head2, u, v, );
AddEdge(e2, Head2, v, u, );
}
} node s;
s.u = , s.step = ; s = BFS(s, );
s.step = ;
s = BFS(s, ); printf("%d\n", bnt-s.step-);
} return ; }
F - Warm up - hdu 4612(缩点+求树的直径)的更多相关文章
- hdu 4607 Park Visit 求树的直径
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4607 题目大意:给你n个点,n-1条边,将图连成一棵生成树,问你从任意点为起点,走k(k<=n) ...
- HDU 4607 Park visit (求树的直径)
解题思路: 通过两次DFS求树的直径,第一次以随意点作为起点,找到距离该点距离最远的点,则能够证明这个点一定在树的直径上,然后以该点为起点进行DFS得到的最长路就是树的直径. 最后的询问,假设K &l ...
- F - Warm up HDU - 4612 tarjan缩点 + 树的直径 + 对tajan的再次理解
题目链接:https://vjudge.net/contest/67418#problem/F 题目大意:给你一个图,让你加一条边,使得原图中的桥尽可能的小.(谢谢梁学长的帮忙) 我对重边,tarja ...
- HDU 4612 Warm up(双连通分量缩点+求树的直径)
思路:强连通分量缩点,建立一颗新的树,然后求树的最长直径,然后加上一条边能够去掉的桥数,就是直径的长度. 树的直径长度的求法:两次bfs可以求,第一次随便找一个点u,然后进行bfs搜到的最后一个点v, ...
- HDU 4612 Warm up —— (缩点 + 求树的直径)
题意:一个无向图,问建立一条新边以后桥的最小数量. 分析:缩点以后,找出新图的树的直径,将这两点连接即可. 但是题目有个note:两点之间可能有重边!而用普通的vector保存边的话,用v!=fa的话 ...
- hdu4612 无向图中随意加入一条边后使桥的数量最少 / 无向图缩点+求树的直径
题意如上,含有重边(重边的话,俩个点就能够构成了边双连通). 先缩点成树,在求数的直径,最远的连起来,剩下边(桥)的自然最少.这里学习了树的直径求法:第一次选随意起点U,进行bfs,到达最远的一个点v ...
- hdu4612 无向图中任意添加一条边后使桥的数量最少 / 无向图缩点+求树的直径
题意如上,含有重边(重边的话,俩个点就可以构成了边双连通). 先缩点成树,在求数的直径,最远的连起来,剩下边(桥)的自然最少.这里学习了树的直径求法:第一次选任意起点U,进行bfs,到达最远的一个点v ...
- (求树的直径)Warm up -- HDU -- 4612
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4612 给一个无向图, 加上一条边后,求桥至少有几个: 那我们加的那条边的两个顶点u,v:一定是u,v之 ...
- hdoj 4612 Warm up【双连通分量求桥&&缩点建新图求树的直径】
Warm up Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total Su ...
随机推荐
- iOS国际化支持
写给自己看: 1.先创建一个国际化文件,用于描述在不同的区域环境,显示不同的value.文件名必须是Localizable.strings,文件的内容稍后再写.
- 登录模块需要用到session留底
<% HttpSession sessions=request.getSession(); Object sessionValues=sessions.getAttribute("ui ...
- c#字符串驻留机制
http://www.cnblogs.com/instance/archive/2011/05/24/2056091.html
- 从服务器将Oracle数据库导出到本地Oracle数据库的方法
1.将服务器上的Oracle数据库导入到本地 在CMD模式下执行以下命令: exp username1/password@服务器端数据库 file=本地硬盘:/文件名.dmp 例如: exp ...
- Oracle_Flashback_技术_总结
Oracle Flashback 技术 总结 Flashback 技术是以Undo segment中的内容为基础的, 因此受限于UNDO_RETENTON参数.要使用flashback 的特性,必须启 ...
- BOM和DOM详解
DOM介绍 D(文档)可以理解为整个Web加载的网页文档,O(对象)可以理解为类似window对象只来的东西,可以调用属性和方法,这里我们说的是document对象,M(模型)可以理解为网页文档的树形 ...
- PLSQL Package dubug方法
初步接触EBS代码修改,花了几个小时搞明白了Package的debug方法, 1.打开需要测试的package,找到需要测试的过程,右键选择测试 2.在测试窗口中初始化过程的入参,点击测试按钮开始调试 ...
- Javascript模块化编程:模块的写法
声明:本文转载自:阮一峰的网络日志,原文地址http://www.ruanyifeng.com/blog/2012/10/javascript_module.html,http://www.ruany ...
- 临时设置 selinux
setenforce 0 ##设置SELinux 成为permissive模式 ##setenforce 1 设置SELinux 成为enforcing模式
- Spring Cp30配置
1.配置db.properties <bean id= "propertyConfigurer" class="org.springframework.beans. ...