Codeforces 1000E We Need More Bosses (边双连通+最长链)
<题目链接>
题目大意:
给定一个$n$个节点$m$条边的无向图,问你对任意两点,最多有多少条特殊边,特殊边指删除这条边后,这两个点不能够到达。
解题分析:
特殊变其实就是指割边,题意就是问你任意两点的路径之间,割边的最大数量。比较裸的题目,由边双连通和树的直径拼凑而成。
用边双连通缩完点之后,树形DP算出最长链即可。
#include <bits/stdc++.h>
using namespace std;
template<typename T>
inline void read(T&x){
x=;int f=;char ch=getchar();
while(ch<'' ||ch>''){ if(ch=='-')f=-; ch=getchar(); }
while(ch>='' && ch<=''){ x=x*+ch-''; ch=getchar(); }
x*=f;
}
#define pb push_back
#define REP(i,s,t) for(int i=s;i<=t;i++)
#define clr(a,b) memset(a,b,sizeof(a))
const int N = 3e5+;
int n,m,tot,top,bcc;
int head1[N],head2[N],dfn[N],bel[N],cnt1,cnt2;
int low[N],instk[N],stk[N];
vector<int>G[N];
struct Edge{ int from,to,nxt; }e1[N<<],e2[N<<];
int ans;
inline void init(){
REP(i,,n)G[i].clear();
cnt1=cnt2=tot=top=bcc=;
clr(dfn,);clr(bel,);
clr(head1,-);clr(head2,-);
}
inline void add1(int u,int v){
e1[cnt1]=(Edge){u,v,head1[u]};head1[u]=cnt1++;
}
inline void add2(int u,int v){
e2[cnt2]=(Edge){u,v,head2[u]};head2[u]=cnt2++;
}
void Tarjan(int u,int pre){
dfn[u]=low[u]=++tot;
instk[u]=;stk[++top]=u;
bool fp=false;
for(int i=head1[u];~i;i=e1[i].nxt){
int v=e1[i].to;
if(v==pre && !fp){ fp=true;continue; }
if(!dfn[v]){
Tarjan(v,u);
low[u]=min(low[u],low[v]);
}else if(instk[v])low[u]=min(low[u],dfn[v]);
}
if(dfn[u]==low[u]){
++bcc;
while(true){
int v=stk[top--];
instk[v]=;
bel[v]=bcc;
G[bcc].pb(v);
if(u==v)break;
}
}
}
inline void getMap(){
for(int i=;i<cnt1;i++){ //缩点
int u=e1[i].from,v=e1[i].to;
if(bel[u]!=bel[v])add2(bel[u],bel[v]);
}
} int dp1[N],dp2[N];
//树形DP求树的直径
void dfs(int u,int pre){
for(int i=head2[u];~i;i=e2[i].nxt){
int v=e2[i].to;
if(v==pre)continue;
dfs(v,u);
if(dp1[v]+>dp1[u])dp2[u]=dp1[u],dp1[u]=dp1[v]+;
else if(dp1[v]+>dp2[u])dp2[u]=dp1[v]+;
}
ans=max(ans,dp1[u]+dp2[u]);
} int main(){
init();
read(n);read(m);
REP(i,,m){
int u,v;read(u);read(v);
add1(u,v);add1(v,u);
}
Tarjan(,-);
getMap();
dfs(,-); //进行树形DP求最长链
cout<<ans<<endl;
}
Codeforces 1000E We Need More Bosses (边双连通+最长链)的更多相关文章
- CodeForces - 1000E We Need More Bosses
题面在这里! 依然一眼题,求出割边之后把图缩成一棵树,然后直接求最长链就行了2333 #include<bits/stdc++.h> #define ll long long using ...
- E - We Need More Bosses CodeForces - 1000E (tarjan缩点,树的直径)
E - We Need More Bosses CodeForces - 1000E Your friend is developing a computer game. He has already ...
- 边双连通缩点+树dp 2015 ACM Arabella Collegiate Programming Contest的Gym - 100676H
http://codeforces.com/gym/100676/attachments 题目大意: 有n个城市,有m条路,每条路都有边长,如果某几个城市的路能组成一个环,那么在环中的这些城市就有传送 ...
- poj 3694 Network 边双连通+LCA
题目链接:http://poj.org/problem?id=3694 题意:n个点,m条边,给你一个连通图,然后有Q次操作,每次加入一条边(A,B),加入边后,问当前还有多少桥,输出桥的个数. 解题 ...
- hdu 4612 Warm up 双连通+树形dp思想
Warm up Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others) Total S ...
- HDU 4612 Warm up (边双连通分量+DP最长链)
[题意]给定一个无向图,问在允许加一条边的情况下,最少的桥的个数 [思路]对图做一遍Tarjan找出桥,把双连通分量缩成一个点,这样原图就成了一棵树,树的每条边都是桥.然后在树中求最长链,这样在两端点 ...
- HDU-4612 Warm up 边双连通分量+缩点+最长链
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4612 简单图论题,先求图的边双连通分量,注意,此题有重边(admin还逗比的说没有重边),在用targ ...
- poj1515--Street Directions(边的双连通)
给一个无向图,要求变成强连通的有向图,需要保留哪些边. 边的双连通,对于桥保留两条边,其他的只保留一条边.求双连通的过程中记录保留边. /******************************* ...
- poj3177--Redundant Paths(边的双连通)
有n个牧场,Bessie 要从一个牧场到另一个牧场,要求至少要有2条独立的路可以走.现已有m条路,求至少要新建多少条路,使得任何两个牧场之间至少有两条独立的路.两条独立的路是指:没有公共边的路,但可以 ...
随机推荐
- nbench
http://www.math.utah.edu/~mayer/linux/bmark.html nbench-byte-2.2.3 --> http://www.math.utah.edu/ ...
- 搭建vue项目并启动vue项目
链接地址:https://blog.csdn.net/aa792978017/article/details/82939483 Vue.js是现在比较优秀的Web前端框架,下面开始从零开始搭建一个Vu ...
- C++ begin()和end()
begin(a)指向数组a的第一个元素,end(a)指向数组a最后一个元素之后的一个元素 #include <iostream> using namespace std; int main ...
- [洛谷P1353] 跑步Running
问题描述 奶牛们打算通过锻炼来培养自己的运动细胞,作为其中的一员,贝茜选择的运动方式是每天进行N(1 <= N <= 10,000)分钟的晨跑.在每分钟的开始,贝茜会选择下一分钟是用来跑步 ...
- hdu 6205: card card card【输入挂】
题目链接 感谢 http://blog.csdn.net/txgang/article/details/77568491 以下供参考 getchar读入法 2683MS FastIO法 MX=1e2 ...
- Linux内核设计与实现 总结笔记(第四章)进程调度
进程调度 调度程序负责决定将哪个进程投入运行,何时运行以及运行多长时间. 调度程序没有太复杂的原理,最大限度地利用处理器时间的原则是,只要有可以执行的进程,那么就总会有进程正在执行. 一.多任务 多任 ...
- B/S大文件断点续传
一. 功能性需求与非功能性需求 要求操作便利,一次选择多个文件和文件夹进行上传:支持PC端全平台操作系统,Windows,Linux,Mac 支持文件和文件夹的批量下载,断点续传.刷新页面后继续传输. ...
- Ubuntu安装及sshd服务安装,yum安装等总结
vm网络选择自定义.指定的虚拟网络,自动桥连. 1.设置root初始密码 ubuntu安装好后,root初始密码(默认密码)不知道,需要设置.1.先用安装时候的用户登录进入系统2.输入:sudo ...
- shapefile文件数据结构
头部 点 线 面 序号 x,y,... 线 序号 1,2 面 序号 1,2,3 拓扑检查 ... <GIS数据结构与算法>
- 虚拟机安装linux遇到的问题
1.运行 yum -y update,提示没有权限,改为sudo yum -y update后,提示没有已启用的仓库.网上查找发现没有yum的库,然后开始安装yum. sudo apt-get in ...