BZOJ 4890: [Tjoi2017]城市 树形dp
标签:树形dp,枚举,树的直径
一上来看到这个题就慌了,只想到了 $O(n^3)$ 的做法.
碰到这种题时要一步一步冷静地去分析,观察数据范围.
首先,$n\leqslant 5000$,所以可以先 $O(n)$ 枚举切断哪条边.
而如果暴力枚举连哪条边的话时间就是爆炸的,不妨冷静地分类讨论一下.
当断掉这条边后,就形成了两个小树.
那么,新树的直径无外乎只有 2 种情况:两个小树中直径的较大值(只经过一棵树的点)/经过两棵树的点.
对于第一种情况,当我们断掉这条边时就是确定好的,可以直接 O(n) 算.
而对于第二种情况,既然是每棵树都要经过一些点,不妨选择每棵树中延伸长度最小的直接连上.
由于这两种情况都是互不影响的,所以可以直接取最小值.
冷静分析,分类讨论.
#include <bits/stdc++.h>
using namespace std;
#define setIO(s) freopen(s".in","r",stdin)
const int N=5010;
int n,cnt=1,ans=453533453,tmp;
int hd[N],to[N<<1],nex[N<<1],dis[N<<1],f[N],g[N],maxson[N],check[N<<1],val[N<<1];
inline void add(int u,int v,int c)
{
nex[++cnt]=hd[u],hd[u]=cnt,to[cnt]=v,val[cnt]=c;
}
void dfs1(int u,int ff)
{
for(int i=hd[u];i;i=nex[i])
{
int v=to[i];
if(v==ff||check[i]) continue;
dfs1(v,u);
tmp=max(tmp,f[u]+f[v]+val[i]);
if(f[v]+val[i]>f[u]) g[u]=f[u],f[u]=f[v]+val[i],maxson[u]=v;
else if(f[v]+val[i]>g[u]) g[u]=f[v]+val[i]; }
}
void dfs2(int x,int ff,int maxx)
{
tmp=min(tmp,max(maxx,f[x]));
for(int i=hd[x];i;i=nex[i])
{
int v=to[i];
if(v==ff||check[i]) continue;
if(maxson[x]==v) dfs2(v,x,max(g[x]+val[i],maxx+val[i]));
else dfs2(v,x,max(f[x]+val[i],maxx+val[i]));
}
}
inline void init()
{
memset(f,0,sizeof(f));
memset(g,0,sizeof(g));
memset(maxson,0,sizeof(maxson));
}
int main()
{
// setIO("input");
int i,j;
scanf("%d",&n);
for(i=1;i<n;++i)
{
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
add(u,v,w),add(v,u,w);
}
for(i=2;i<=cnt;i+=2)
{
init();
int d1,d2,d3,d4,x=to[i],y=to[i^1];
check[i]=check[i^1]=1;
tmp=0, dfs1(x,0), d1=tmp;
tmp=0, dfs1(y,0), d2=tmp;
tmp=10000000, dfs2(x,0,0), d3=tmp;
tmp=10000000, dfs2(y,0,0), d4=tmp;
ans=min(ans,max(max(d1,d2),d3+d4+val[i]));
check[i]=check[i^1]=0;
}
printf("%d\n",ans);
return 0;
}
BZOJ 4890: [Tjoi2017]城市 树形dp的更多相关文章
- [BZOJ 4890][TJOI2017]城市
传送门 $ \color{green} {solution : }$ 我们可以暴力枚举断边,然后 $ O(n) $ 的跑一次换根 $ dp $,然后复杂度是 $ O(n * n) $ 的 #inclu ...
- Bzoj 1131[POI2008]STA-Station (树形DP)
Bzoj 1131[POI2008]STA-Station (树形DP) 状态: 设\(f[i]\)为以\(i\)为根的深度之和,然后考虑从他父亲转移. 发现儿子的深度及其自己的深度\(-1\) 其余 ...
- BZOJ 4726: [POI2017]Sabota? 树形dp
4726: [POI2017]Sabota? 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4726 Description 某个公司有n ...
- bzoj 2286(虚树+树形dp) 虚树模板
树链求并又不会写,学了一发虚树,再也不虚啦~ 2286: [Sdoi2011]消耗战 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 5002 Sol ...
- BZOJ 4472 [Jsoi2015]salesman(树形DP)
4472: [Jsoi2015]salesman Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 417 Solved: 192[Submit][St ...
- bzoj 3829: [Poi2014]FarmCraft 树形dp+贪心
题意: $mhy$ 住在一棵有 $n$ 个点的树的 $1$ 号结点上,每个结点上都有一个妹子. $mhy$ 从自己家出发,去给每一个妹子都送一台电脑,每个妹子拿到电脑后就会开始安装 $zhx$ 牌杀毒 ...
- BZOJ 1369: [Baltic2003]Gem(树形dp)
传送门 解题思路 直接按奇偶层染色是错的,\(WA\)了好几次,所以要树形\(dp\),感觉最多\(log\)种颜色,不太会证. 代码 #include<iostream> #includ ...
- bzoj 3743 [Coci2015]Kamp——树形dp+换根
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3743 树形dp+换根. “从根出发又回到根” 减去 “mx ” . 注意dfsx里真的要改那 ...
- BZOJ 1812: [Ioi2005]riv( 树形dp )
树背包, 左儿子右兄弟来表示树, dp(x, y, z)表示结点x, x的子树及x的部分兄弟共建y个伐木场, 离x最近的伐木场是z时的最小代价. 时间复杂度O(N^2*K^2) ----------- ...
随机推荐
- 对于Node中Express框架的中间件概念的感知
中间件是什么呢? 中间件就是客户端http请求发起传送到服务器和服务器返回响应之间的一些处理函数. 为什么要使用中间件? 通过中间件,可以对数据进行操作使得我们能方便地操作请求数据编写服务器响应.如b ...
- yii框架里DetailView视图和GridView的区别
1,首先从语义上分析 DetailView是数据视图,用于显示一条记录的数据,相当于网页中的详情页 GridView是网格视图,用于显示数据表里的所有记录,相当于网页里的列表页 2.用法上的区别 首先 ...
- 深度剖析java中JDK动态代理机制
https://www.jb51.net/article/110342.htm 本篇文章主要介绍了深度剖析java中JDK动态代理机制 ,动态代理避免了开发人员编写各个繁锁的静态代理类,只需简单地指定 ...
- 1、Linux安装前的准备
1.硬盘和分区 1.1 Linux中如何表示硬盘和分区 硬盘划分为 主分区.扩展分区和逻辑分区三部分. 主分区只有四个: 扩展分区可以看成是一个特殊的主分区类型,在扩展分区中还可以建立相应的逻辑分区 ...
- How to do SSH Tunneling (Port Forwarding)
How to do SSH Tunneling (Port Forwarding) In this post we will see how ssh works?, what is SSH tunne ...
- 复杂dic的文件化存储和读取问题
今天遇到一个难题.整出一个复杂的dic,里面不仅维度多,还含有numpy.array.超级复杂.过程中希望能够存储一下,万一服务器停了呢?万一断电了呢? 结果存好存,取出来可就不是那样了.网上搜索了很 ...
- Java框架之MyBatis框架(二)
Mybatis框架是相对于优化dao层的框架,其有效的减少了频繁的连接数据库(在配置文件xml中进行配置),将sql语句与java代码进行分离(写在XXXXmapper.xml文件中,一个表对应一个x ...
- windows下binlog问题解决
1.先确定mysql是否开启了binlog show binary logs; 默认情况下是不开启的 2.如何开启 在my.ini配置下添加两个参数 # Binary Logginglog-bin=m ...
- Linux 里的 2>&1 究竟是什么
原文 我们在Linux下经常会碰到nohup command>/dev/null 2>&1 &这样形式的命令.首先我们把这条命令大概分解下: 首先就是一个nohup:表示当 ...
- C语言基础知识-程序流程结构
C语言基础知识-程序流程结构 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.概述 C语言支持最基本的三种程序运行结构:顺序结构,选择结构,循环结构. 顺序结构:程序按顺序执行, ...