https://vjudge.net/problem/Gym-100712H

题意:

给出一个图,求添加一条边后最少的桥数量。

思路:

参考了ZSQ大神的题解http://blog.csdn.net/v5zsq/article/details/61922051

很明显的边—双连通的题目,首先缩点建新图。然后寻找树中的最大直径,这样就能将桥的数量减至最小。

 #include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<vector>
#include<queue>
#include<cmath>
#include<map>
#include<stack>
using namespace std; const int maxn=+; struct Edge
{
int to,next;
bool flag;//标记是否是桥
}edge[maxn*]; stack<int> S;
int n,m;
int head[maxn],tot;
int low[maxn],dfn[maxn],belong[maxn];
int index,top;
int block;//边双连通块数
bool instack[maxn];
int bridge;//桥的数目
int e[maxn][];
int deep; //最长直径
int pos; //最长直径端点 void addedge(int u,int v)
{
edge[tot].to=v,edge[tot].next=head[u],edge[tot].flag=;
head[u]=tot++;
} void Tarjan(int u,int pre)
{
int v;
low[u]=dfn[u]=++index;
S.push(u);
instack[u]=;
for(int i=head[u];~i;i=edge[i].next)
{
v=edge[i].to;
if(v==pre)continue;
if(!dfn[v])
{
Tarjan(v,u);
if(low[u]>low[v])low[u]=low[v];
if(low[v]>dfn[u])
{
bridge++;
edge[i].flag=;
edge[i^].flag=;
}
}
else if(instack[v]&&low[u]>dfn[v])
low[u]=dfn[v];
}
if(low[u]==dfn[u])
{
block++;
do
{
v=S.top(); S.pop();
instack[v]=;
belong[v]=block;
}
while(v!=u);
}
} void init()
{
memset(dfn,,sizeof(dfn));
index=block=top=bridge=tot=;
memset(head,-,sizeof(head));
} //邻接表寻找树的直径
void dfs(int u,int fa,int cnt)
{
if(cnt>deep) {deep=cnt;pos=u;}
for(int i=head[u];~i;i=edge[i].next)
{
int v=edge[i].to;
if(v!=fa) dfs(v,u,cnt+);
}
} int main()
{
//freopen("D:\\input.txt","r",stdin);
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
init();
for(int i=;i<=m;i++)
{
scanf("%d%d",&e[i][],&e[i][]);
addedge(e[i][],e[i][]);
addedge(e[i][],e[i][]);
}
Tarjan(,); //缩点,重建图
tot=;
memset(head,-,sizeof(head));
int ans=;
for(int i=;i<=m;i++)
{
int u=belong[e[i][]], v=belong[e[i][]];
if(u!=v)
{
ans++;
addedge(u,v);
addedge(v,u);
}
} deep=;
dfs(,,);
deep=;
dfs(pos,pos,);
printf("%d\n",ans-deep);
}
return ;
}

最新文章

  1. Spring基础——小的知识点
  2. 怎样查看linux版本
  3. C语言和数据结构的书单-再次推荐
  4. iOS 程序打包,安装流程
  5. bzoj 1483 [HNOI2009]梦幻布丁(链表+启发式合并)
  6. openwrt固件支持3G和4G上网卡
  7. iosOC不可变字典和可变字典
  8. Android——apk反编译
  9. [bzoj1059] [ZJOI2007] 矩阵游戏 (二分图匹配)
  10. redis在Linux上的安装和简单使用
  11. SqlServer 递归查询
  12. 第四十四篇--做一个简单的QQ登录界面
  13. JAVA集合2--Collection架构
  14. margin合并和浮动
  15. vs code軟件操作
  16. Linux中通过Socket文件描述符寻找连接状态介绍
  17. 2.翻译系列:为EF Code-First设置开发环境(EF 6 Code-First系列)
  18. 《操作系统_FCFS和SJF》
  19. javascript原型对象与原型链
  20. failed to load response data

热门文章

  1. Win2003X64位,IIS6.0 32位 浏览报错的解决方案
  2. DNS 知识点
  3. 008-Hadoop Hive sql语法详解3-DML 操作:元数据存储
  4. CentOS 6.4中yum安装配置LAMP服务器(Apache+MySQL+PHP5)
  5. SQL Server 2008数据库手动提交的设置
  6. 我的第一次NGS分析操作
  7. Mysql binlog 安全删除(转载)
  8. Delphi程序调用C#.Net编译的DLL并打开窗体(详解)
  9. vmware12 安装linux centos6
  10. SVN无法Cleanup