[JZOJ 5465] [NOIP2017提高A组冲刺11.9] 道路重建 解题报告 (e-dcc+树的直径)
题目链接:
http://172.16.0.132/senior/#main/show/5465
题目:
小X所居住的X国共有n个城市,有m条无向道路将其连接。作为一个统一的国家,X 城的任意两个城市都可以相互到达。
由于X国正处于地震带上,有时X国中会有至多一条道路发生毁坏,无法使用。如果这条道路的毁坏恰好阻断了某些城市的往来,那么我们称这条道路是危险的。
人们并不喜欢危险的道路,于是人们决定重建恰好一条道路,以减少危险的道路数。请告诉人们,重建恰好一条道路后,危险的道路数最少是多少。
题解:
显然在一个边双里,任意删掉一条边依旧是连通的,也就是说危险的道路其实就是桥
因此我们缩边双,建新图
注意到缩掉所有的边双之后图会变成一棵树,我们就是要在这棵树连边,使得上形成的环最大,环上的边本来是危险的,现在不危险了
显然我们要连的是直径的两个端点,求一遍树的直径就好了
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<iostream>
#include<time.h>
#define mem(x,y) memset(x,y,sizeof(x))
using namespace std; const int N=2e5+;
const int M=1e6+;
int n,m,tot1,tot2,tim,tp,mx,pos;
int h1[N],h2[N],dfn[N],vis[N],belong[N],low[N];
bool brige[M<<];
struct E{
int to,nxt;
}e1[M<<],e2[M<<];
inline char nc(){
static char buf[],*p1=buf,*p2=buf;
return p1==p2&&(p2=(p1=buf)+fread(buf,,,stdin),p1==p2)?EOF:*p1++;
}
inline int read(){
char ch=nc();int s=,f=;
while (ch<''||ch>'') {if (ch=='-') f=-;ch=nc();}
while (ch>=''&&ch<='') {s=(s<<)+(s<<)+ch-'';ch=nc();}
return s*f;
}
void link1(int u,int v){e1[++tot1]=(E){v,h1[u]};h1[u]=tot1;}
void link2(int u,int v){e2[++tot2]=(E){v,h2[u]};h2[u]=tot2;}
void chkmin(int &x,int y){if (y<x) x=y;}
void init(){
mem(h1,);mem(h2,);mem(dfn,);mem(low,);mem(brige,);
tot1=tot2=;
tim=tp=;
}
void tarjan(int x,int pre){
dfn[x]=low[x]=++tim;
for (int i=h1[x];i;i=e1[i].nxt){
int y=e1[i].to;
if (!dfn[y]){
tarjan(y,i);
chkmin(low[x],low[y]);
if (low[y]>dfn[x]) brige[i]=brige[i^]=;
}
else if (i!=(pre^)) chkmin(low[x],dfn[y]);
}
}
void dfs(int x,int edcc){
belong[x]=edcc;vis[x]=;
for (int i=h1[x],y;i;i=e1[i].nxt){
if (vis[y=e1[i].to]||brige[i]) continue;
dfs(y,edcc);
}
}
void dfs1(int x,int len,int pre){
if (len>mx) mx=len,pos=x;
for (int i=h2[x],y;i;i=e2[i].nxt){
if ((y=e2[i].to)==pre) continue;
dfs1(y,len+,x);
}
}
int main(){
freopen("rebuild.in","r",stdin);
freopen("rebuild.out","w",stdout);
while ()
{
n=read();m=read();
if (!n&&!m) break;
init();
for (int i=,u,v;i<=m;i++){
u=read();v=read();link1(u,v);link1(v,u);
}
tarjan(,-);
mem(vis,);
int cnt=;
for (int i=;i<=n;i++) if (!vis[i]) dfs(i,++cnt);
for (int x=;x<=n;x++)
for (int i=h1[x];i;i=e1[i].nxt){
int y=e1[i].to;
if (belong[x]==belong[y]) continue;
link2(belong[x],belong[y]);
}
mx=;
dfs1(,,-);
mx=;
dfs1(pos,,-);
printf("%d\n",cnt-mx);
}
return ;
}
[JZOJ 5465] [NOIP2017提高A组冲刺11.9] 道路重建 解题报告 (e-dcc+树的直径)的更多相关文章
- JZOJ 5462. 【NOIP2017提高A组冲刺11.8】好文章
5462. [NOIP2017提高A组冲刺11.8]好文章 (File IO): input:article.in output:article.out Time Limits: 1000 ms M ...
- JZOJ 5456. 【NOIP2017提高A组冲刺11.6】奇怪的队列
5456. [NOIP2017提高A组冲刺11.6]奇怪的队列 (File IO): input:queue.in output:queue.out Time Limits: 1000 ms Mem ...
- JZOJ 5459. 【NOIP2017提高A组冲刺11.7】密室
5459. [NOIP2017提高A组冲刺11.7]密室 (File IO): input:room.in output:room.out Time Limits: 1000 ms Memory L ...
- JZOJ 5455. 【NOIP2017提高A组冲刺11.6】拆网线
455. [NOIP2017提高A组冲刺11.6]拆网线 (File IO): input:tree.in output:tree.out Time Limits: 1000 ms Memory L ...
- JZOJ 5461. 【NOIP2017提高A组冲刺11.8】购物
5461. [NOIP2017提高A组冲刺11.8]购物 (File IO): input:shopping.in output:shopping.out Time Limits: 1000 ms ...
- 5458. 【NOIP2017提高A组冲刺11.7】质数
5458. [NOIP2017提高A组冲刺11.7]质数 (File IO): input:prime.in output:prime.out Time Limits: 1000 ms Memory ...
- [JZOJ5455]【NOIP2017提高A组冲刺11.6】拆网线
Description 企鹅国的网吧们之间由网线互相连接,形成一棵树的结构.现在由于冬天到了,供暖部门缺少燃料,于是他们决定去拆一些网线来做燃料.但是现在有K只企鹅要上网和别人联机游戏,所以他们需要把 ...
- 【NOIP2017提高A组冲刺11.8】好文章
#include<algorithm> #include<iostream> #include<cstring> #include<cstdio> us ...
- 【NOIP2017提高A组冲刺11.6】拆网线
和syq大兄弟吐槽题目不小心yy出了正解.. 最优的选法就是选两个两个相互独立的,欸这不就是最大匹配吗?那多的企鹅就新加一条边呗?不够的就除以2上取整呗? 欸?AC了? 树也是一个二分图,最大匹配=最 ...
随机推荐
- lightoj--1245--Harmonic Number (II)(数学推导)
Harmonic Number (II) Time Limit: 3000MS Memory Limit: 32768KB 64bit IO Format: %lld & %llu S ...
- oracle 实时查询最耗CPU资源的SQL语句
1. 先通过top命令查看产用资源较多的spid号 2.查询当前耗时的会话ID,用户名,sqlID等: select sid,serial#,machine,username,program,sql_ ...
- Java并发包
刚看到一篇总结的比较全的JUC包总结,转载如下: 1. java.util.concurrent - Java 并发工具包 Java 5 添加了一个新的包到 Java 平台,java.util.con ...
- 9. Palindrome Number[E]回文数
题目 Determine whether an integer is a palindrome. An integer is a palindrome when it reads the same b ...
- Python笔记(六)
# -*-coding:utf-8-*- # 模块 # 模块是一个Python文件,以.py结尾,能让你有逻辑的组织Python代码 # 可以通过import引入模块 import Course_5 ...
- 互联网时代: 从Uber的供需匹配看开发需求
每次看电影中的有钱人都有专属司机接送,只要坐在车里,就有人帮忙开车门.提行李及关车门.感觉是非现实的遥远画面,现在却有机会可以在日常生活中成真! 2009年Travis Kalanick及Garret ...
- CorelDRAW X8制作金属质感3D立体按钮
本教程教您使用CorelDRAW X8制作金属质感3D立体按钮.绘图中主要应用渐变填充技巧为立体按钮表现物体质感和丰富的色彩变化,最后实现的效果也是不错的,是很实用的案例,教程难度一般,完成图如下: ...
- 悦享双节,Guitar Pro也来凑份热闹!
光阴似箭,又是一个金秋的十月,祖国迎来了第68个生日,不同以往的是今年的中秋佳节与国庆假日重叠在一起了,这算不算是喜上加喜呢? 提到国庆人们的耳边总是会响起了一遍又一遍的国歌“起来,起来不愿做奴隶的人 ...
- Jmeter数据库测试
Jmeter安装 Jmeter是纯java程序,所以在安装jmeter之前需要先安装JDK,并配置JDK路径,然后开始安装Jmeter. 进入Jmeter官网(https://jmeter.apach ...
- Spring Boot 20170913
SpringBoot 是做微服务的,比如只用来发邮件,只用来上载文件等等.优点是开发极其简单,约定大于俗成,缺点是不适合小型项目.通常用来分解大型项目,做成多个微服务. 参考: http://www. ...