标签:树形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的更多相关文章

  1. [BZOJ 4890][TJOI2017]城市

    传送门 $ \color{green} {solution : }$ 我们可以暴力枚举断边,然后 $ O(n) $ 的跑一次换根 $ dp $,然后复杂度是 $ O(n * n) $ 的 #inclu ...

  2. Bzoj 1131[POI2008]STA-Station (树形DP)

    Bzoj 1131[POI2008]STA-Station (树形DP) 状态: 设\(f[i]\)为以\(i\)为根的深度之和,然后考虑从他父亲转移. 发现儿子的深度及其自己的深度\(-1\) 其余 ...

  3. BZOJ 4726: [POI2017]Sabota? 树形dp

    4726: [POI2017]Sabota? 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4726 Description 某个公司有n ...

  4. bzoj 2286(虚树+树形dp) 虚树模板

    树链求并又不会写,学了一发虚树,再也不虚啦~ 2286: [Sdoi2011]消耗战 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 5002  Sol ...

  5. BZOJ 4472 [Jsoi2015]salesman(树形DP)

    4472: [Jsoi2015]salesman Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 417  Solved: 192[Submit][St ...

  6. bzoj 3829: [Poi2014]FarmCraft 树形dp+贪心

    题意: $mhy$ 住在一棵有 $n$ 个点的树的 $1$ 号结点上,每个结点上都有一个妹子. $mhy$ 从自己家出发,去给每一个妹子都送一台电脑,每个妹子拿到电脑后就会开始安装 $zhx$ 牌杀毒 ...

  7. BZOJ 1369: [Baltic2003]Gem(树形dp)

    传送门 解题思路 直接按奇偶层染色是错的,\(WA\)了好几次,所以要树形\(dp\),感觉最多\(log\)种颜色,不太会证. 代码 #include<iostream> #includ ...

  8. bzoj 3743 [Coci2015]Kamp——树形dp+换根

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3743 树形dp+换根. “从根出发又回到根” 减去 “mx ” . 注意dfsx里真的要改那 ...

  9. BZOJ 1812: [Ioi2005]riv( 树形dp )

    树背包, 左儿子右兄弟来表示树, dp(x, y, z)表示结点x, x的子树及x的部分兄弟共建y个伐木场, 离x最近的伐木场是z时的最小代价. 时间复杂度O(N^2*K^2) ----------- ...

随机推荐

  1. Label&Button

    Button中的bg参数设置按钮背景颜色,fg参数设置字体颜色 pack中的fill参数告诉Packer让QUIT按钮占据剩余的水平空间,而expand参数则引导它填充整个水平可视空间,将按钮拉伸到左 ...

  2. Vivado关联Modelsim进行联合仿真

    Vivado自带仿真工具,但是有点慢,关联Modelsim联合仿真是最好的,注意Modelsim必须是10.7以上版本. 1.安装并成功破解Modelsim 10.7. 2.打开Vivado,点击 T ...

  3. Compact Middle Packages

    idea工具进行Java开发,在项目视图,默认是将package层级以简洁显示的,如下图: 但有时,我们希望不要使用这种模式,比如:某个父包下,有一个子包,想在父包下,增加一个包,可是来时增加在子包下 ...

  4. C#泛型集合之——队列与堆栈

    队列与堆栈基础 队列 1.操作: (1)创建及初始化: Queue<类型> 队列名 =new Queue<类型>()://空队列,无元素 Queue<类型> 队列名 ...

  5. 使用NODEJS实现JSONP的实例

    JSONP与JSON只有一字之差,我们在使用Jquery的Ajax调用的时候也是使用相同的方法来调用,两者的区别几乎只在于使用的dataType这个属性的不同.但是实际上JSON和JSONP是完全不同 ...

  6. Java之路---Day05

    2019-10-19-21:09:31 面向对象的封装性 封装性 概念:封装就是将一些细节信息隐藏起来,对于外界不可见 面向对象封装性在Java中的体现 1.方法就是一种封装 public class ...

  7. el-table单元格样式更改

    前几天遇到一个关于el-table表格样式的问题一直没解决 因为在el-table-column加样式并不生效所以更改起来比较麻烦 后来了看来element官方文档和在一些关于此方面的博客,使用了一个 ...

  8. react学习记录(三)——状态、属性、生命周期

    react的状态state React 里,只需更新组件的 state,然后根据新的 state 重新渲染用户界面(不要操作 DOM) class Clock extends React.Compon ...

  9. SOFABoot&SOFATracer

    SOFABoot快速开始 SOFABoot介绍 SOFABoot 是蚂蚁金服开源的基于 Spring Boot 的研发框架,它在 Spring Boot 的基础上,提供了诸如 Readiness Ch ...

  10. How to set up "lldb_codesign" certificate!

    To use the in-tree debug server on macOS, lldb needs to be code signed. TheDebug, DebugClang and Rel ...