题目依然链接

题意:

  从根节点出发,每条边走两遍回到根节点,走边用时1,到达某个节点之后开始计时,到该节点最大的计时数时结束,回到根节点时根节点开始计时。求让所有计时都结束的最小时间。

Solve:

  很容易想到树形Dp,但是怎么Dp呢,因为记时开始后你还可以移动,所以并不是子树的简单累加,而是某种方法取max,我们先把状态定义下来,Dp[i]表示把以i为根的子树全部计时结束后需要的最小时间,那么我们要想一下怎么转移。

  如果我们已经知道了遍历顺序我们可以怎么转移,那就是Dp[i]=max(a[i],Dp[son1]+has1*2-1,Dp[son2]+has2*2-1+...+Dp[sonn]+hasn*n-1),hasj表示走到第j个儿子总共走的边数。

  为什么也是显而易见的,因为计时是同步的,所以我们只需取max就可以了。

  某大佬:我觉得有问题。

  我:一会儿为您解释。。。

  好的这个不太严谨的转移方程就写出来了,注意,是不太严谨的。

  那么我们怎么确定走儿子的顺序呢?这个再枚举就不太好了,我们要想一个好点的办法,这里其实很好想到要根据某个值进行排序,根据什么呢?其实这个只要稍微画画图就能想明白,如果Dp[i]+2*son[j]>Dp[j]+2*son[i].则i在j前面,这个怎么想到的呢,可以先画一下两个儿子的情况(这种很好证明)再类比一下,类别出结果再进行证明,怎么证明呢,这是我的证明方法:如果j在i前面,我们交换i和j的顺序至少不会更差(可以自己推推不等式,不难),所以我们可以直接让i在j前面,然后又有一个小小的问题,这样定义<会出问题吗,比如出现a>b且b<a或a>b且b>c且c>a,使sort函数死掉。其实并不会Dp[i]+2*son[j]>Dp[j]+2*son[i]就等价于Dp[i]-2*son[i]>Dp[j]-2*son[j]而Dp[i]-2*son[i]对于每个i是一个定值,所以并没有任何问题。

  好了顺序我们知道了,然后转移方程我们也知道了,但是刚才也有说到:转移方程不是很严谨(如下树,权值均为1),怎么让它严谨起来呢,很简单,感谢题目,让我们不用做任何改动就可以严谨起来(题目要求最后回来再计时根),想一想为什么。

  当然因为这个,我们也要做一些其他操作,这个各位应该都能想到解决方案。

  然后就是用不用开long long,多开当然没事,但是这一题不用开,不是数据水因为Dp最大也超不过n*2+max(a[i]),超不了int,但是多开一些没问题。

代码:

  

#include <cstdio>
#include <algorithm>
#include <string>
using namespace std;
const int maxn=+;
struct E{
int next;
int to;
E(){
next=to=;
}
}ed[maxn*];
int a[maxn];
int head[maxn];
int Dp[maxn];
int jl[maxn];
int er[maxn];
bool Cm(int a,int b){
return Dp[a]+er[b]*>Dp[b]+*er[a];//对什么进行排序想清楚
}
int Dfs(int x,int fa){
for(int i=head[x];i;i=ed[i].next){
if(ed[i].to==fa)
continue;
else{
Dfs(ed[i].to,x);
er[x]+=er[ed[i].to]+;
}
}
int js=;
for(int i=head[x];i;i=ed[i].next){//要先Dfs再记录,前面的题里有提到
if(ed[i].to==fa)
continue;
else{
js++;
jl[js]=ed[i].to;
}
}
if(!js){
Dp[x]=a[x];
return ;
}
sort(jl+,jl++js,Cm);
Dp[x]=a[x];
int has=;
for(int i=;i<=js;i++){
has++;
Dp[x]=max(Dp[jl[i]]+*has-,Dp[x]);
has+=er[jl[i]];
}
return er[x];
}
int tot;
void J(int a,int b){
tot++;
ed[tot].to=b;
ed[tot].next=head[a];
head[a]=tot;
}
int main(){
int n;
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d",&a[i]);
int js1,js2;
for(int i=;i<=n-;i++){
scanf("%d%d",&js1,&js2);
J(js1,js2);
J(js2,js1);
}
int js=a[];//为保证最后再弄第一个的一些操作
a[]=;
Dfs(,);
printf("%d",max(js+*n-,Dp[]));
return ;
}

 

FarmCraft,又是Dp的更多相关文章

  1. BZOJ3829[Poi2014]FarmCraft——树形DP+贪心

    题目描述 In a village called Byteville, there are   houses connected with N-1 roads. For each pair of ho ...

  2. 【BZOJ3829】[Poi2014]FarmCraft 树形DP(贪心)

    [BZOJ3829][Poi2014]FarmCraft Description In a village called Byteville, there are   houses connected ...

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

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

  4. UVA 11137 Ingenuous Cubrency(dp)

    Ingenuous Cubrency 又是dp问题,我又想了2 30分钟,一点思路也没有,最后又是看的题解,哎,为什么我做dp的题这么烂啊! [题目链接]Ingenuous Cubrency [题目类 ...

  5. 动态规划——数位dp

    通过先前在<动态规划——背包问题>中关于动态规划的初探,我们其实可以看到,动态规划其实不是像凸包.扩展欧几里得等是具体的算法,而是一种在解决问题中决策的思想.在不同的题目中,我们都需要根据 ...

  6. [USACO 2012 Open Gold] Bookshelf【优化dp】

    传送门1:http://www.usaco.org/index.php?page=viewproblem2&cpid=138 传送门2:http://www.lydsy.com/JudgeOn ...

  7. CF Round #367 C题

    题目 链接:http://codeforces.com/contest/706/problem/C 好像又是DP... dp[i][0]表示第i个字符串不翻转成字典序排列的花费,dp[i][1]表示第 ...

  8. {POJ}{动态规划}{题目列表}

    动态规划与贪心相关: {HDU}{4739}{Zhuge Liang's Mines}{压缩DP} 题意:给定20个点坐标,求最多有多少个不相交(点也不相交)的正方形 思路:背包问题,求出所有的正方形 ...

  9. Lyk Love painting/convex hull/mumsic

    这场比赛真的是...打的好颓废啊... 所有题面的传送门 T1 分析: 我们发现 二分答案 + \(n^3\) \(dp\) 判断可行性 可以拿 60 分(于是就写好了啊!) 然后我们发现上面的 \( ...

随机推荐

  1. OO第一作业周期(前四周)总结

    前言:回顾这三次的作业,在一次次的练习下渐渐理解了一些Java的一些基本知识和类与对象的含义与用法,也找到了很多自身的不足和问题,主要是反映类与类之间的关系没有理解到位,这次总结后又有了新的感悟和理解 ...

  2. 智能家居巨头 Aqara 基于 KubeSphere 打造物联网微服务平台

    背景 从传统运维到容器化的 Docker Swarm 编排,从 Docker Swarm 转向 Kubernetes,然后在 Kubernetes 运行 SpringCloud 微服务全家桶,到最终拥 ...

  3. 基于httpclient的一些常用方法封装

    package com.util; import java.io.IOException; import java.io.UnsupportedEncodingException; import ja ...

  4. mysql内连接

    inner join(等值连接) 只返回两个表中联结字段相等的行 select * from role_action ra INNER JOIN action a on ra.action_id = ...

  5. @font-face规则指定字体

    兼容性写法: @font-face { font-family: '字体名'; src: url('字体名.eot'); /* IE9 兼容模式 */ src: url('字体名.eot?#iefix ...

  6. UWP实现第二字幕并且跟随系统的设置

    话不多说,先看一下最终效果 系统设置默认 在系统设置里面更改字幕的显示效果 需求 要求播放器可以显示第二字幕,类似旁白的文字解释.比如片中出现了一个专业术语,这个时候观众可能有些疑惑.所以需要在屏幕上 ...

  7. 关于时间格式 GMT,UTC,CST,ISO

    GMT: 格林尼治所在地的标准时间 UTC: 协调世界时,又称世界统一时间.世界标准时间.国际协调时间.由于英文(CUT)和法文(TUC)的缩写不同,作为妥协,简称UTC. 协调世界时是以原子时秒长为 ...

  8. phpmyadmin通过慢查询日志getshell连载(二)

    这是phpmyadmin系列渗透思路的第二篇文章,前面一篇文章阐述了通过全局日志getshell,但是还有一个日志可以getshell,那就是本次实验的慢查询日志,操作类似,毕竟实战中多一条路就多一次 ...

  9. mapper.xml文件映射配置

    一.导入约束 为全局配置文件绑定dtd约束: 1)联网会自动绑定 2)没网的时候[/org/apache/ibatis/builder/xml/mybatis-3-mapper.dtd]:解压myba ...

  10. opencv C++图像读取

    int main(){ cv::Mat img=cv::imread("/home/nan/图片/highdeepth/starry.jpg",cv::IMREAD_REDUCED ...