地图上的 n个城市,由 n-1条道路连接,且任意两个城市连通。
除 1号城市之外的每个都有 一台计算机,安装软件号城市之外的每个都有 一台计算机,安装软件一个 自己的安装时间。
住在 1号城市的蒟蒻要给这 n-1台计算机装配软件,他可以沿着 n-1条道路 行走,每条道路花费的时间为 1。
蒟蒻在第 0时刻出发,他每走到一个城市就立给该的电脑装软件。
因为蒟蒻急着回家,所以他希望在最快到,因为蒟蒻急着回家,所以他希望在最快到 1号城市的基础上,所有电脑完 号城市的基础上,所有电脑完成。

【数据规模和约定】
对于 30%的数据,2<=n<=10,1<=每台计算机安装软件时间<=100;
对于 60%的数据,2<=n<=1000,1<=每台计算机安装软件时间<=100000;
对于 100%的数据,2<=n<=500000,1<=每台计算机安装软件的时间<=10^9。

注意一定要保证回去时间最小,图又是一颗树,所以每条边一定经过两次,而一旦到达一个点,一定要遍历完当前点的所有子树再返回。
这道题设L[k]为从k开始,按照最优决策遍历完所有k的子树,所有软件完成安装所需的最小时间。s[k]是k的子树大小。
注意到这样一个问题,若当前节点有两种选择,1和2,我们所需要做的决策就是
max(l[1],l[2]+2*s[1]),max(l[1]+2*s[2],l[2])这两个数哪一个小,就选小的决策,其中第一个代表先走1,第二个代表先走2。
假设一个节点有q个子树,我们做出了q个决策,那么显然,交换任意两个相邻的决策顺序不会影响其它决策,然后多做几次,选出一个最优的决策。
我的方法是证明在这q个子树中,第一步要么走l最大的,要么走l次大的。因为不走l最大的的原因是其size过大,而毫无疑问,这个事件对l次大的影响是最大的,所以结论成立。
然后按l排序,for i=2 to n,判断每个和第1个哪个更优,更优的就取走,bas+=2*s[k],剩下的没被取走的就作为第一个。

PS:这题略卡常,用vector存图会TLE

 #include<cstdio>
#include<algorithm>
#define maxn 500005
using namespace std;
int fa[maxn];
long long size[maxn],x[maxn],t[maxn],n,m,head[maxn],cnt,sf[maxn];
struct edge{int to,next;}e[*maxn];
void insert(int u,int v){
e[++cnt].to=v;e[cnt].next=head[u];head[u]=cnt;
e[++cnt].to=u;e[cnt].next=head[v];head[v]=cnt;
}
struct sd{
int u;long long v;
bool operator < (const sd & g1) const{
return v>g1.v;}
}q[*maxn];
long long read(){
long long ret=;char ch=getchar();
while(ch<''||ch>'') ch=getchar();
while(ch>=''&&ch<='') ret=ret*+ch-'',ch=getchar();
return ret;
}
void dfs(int k,int f){
fa[k]=f;
for(int i=head[k];i;i=e[i].next){
if(e[i].to==f) continue;
dfs(e[i].to,k);
size[k]+=size[e[i].to];
}size[k]++;
}
void dfs2(int k,int bas){
long long h,tot=bas;
for(int i=head[k];i;i=e[i].next){
if(e[i].to==fa[k]) continue;
dfs2(e[i].to,tot);tot++;
q[tot].u=e[i].to;
q[tot].v=t[e[i].to];
}
t[k]=max(t[k],sf[k]);
if(!(tot-bas)) return;
sort(q+bas+,q+tot+);long long bsi=;
for(int i=bas+;i<=tot;i++){
if(q[bas+].v+*size[q[i].u]<q[i].v+*size[q[bas+].u]){
t[k]=max(t[k],q[i].v+bsi);
bsi+=*size[q[i].u];
}
else{
t[k]=max(t[k],q[bas+].v+bsi);
bsi+=*size[q[bas+].u];
q[bas+].v=q[i].v;q[bas+].u=q[i].u;
}
}
t[k]=max(t[k],t[q[bas+].u]+bsi);
}
int main(){
freopen("software.in","r",stdin);
freopen("software.out","w",stdout);
n=read();
for(int i=;i<=n;i++)sf[i]=read();long long a,b;
for(int i=;i<n;i++){
a=read();b=read();
insert(a,b);
}
dfs(,);
dfs2(,);
printf("%lld\n",t[]);
return ;
}

noip模拟赛 软件software的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  3. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  4. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  5. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  6. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  7. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  8. CH Round #58 - OrzCC杯noip模拟赛day2

    A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...

  9. CH Round #52 - Thinking Bear #1 (NOIP模拟赛)

    A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...

随机推荐

  1. centos 升级GCC/G++

    #get rep yum install centos-release-scl-rh #yum install centos-release-scl # install g++ 5.2.1 yum - ...

  2. datagridview中combobox类型的cell选中一个下拉列表之后,立即生效的事件

    public event EventHandler CurrentCellDirtyStateChanged 当单元格的内容已更改,但更改尚未保存时,该单元格将标记为已修改. 此事件通常会在以下情况下 ...

  3. 二、理解over()函数

    1.1.两个order by的执行时机分析函数是在整个sql查询结束后(sql语句中的order by的执行比较特殊)再进行的操作, 也就是说sql语句中的order by也会影响分析函数的执行结果: ...

  4. sdut2164Binomial Coeffcients(组合数求模)

    http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2164 贴一篇写组合数求mod比较好的帖子 这里 ...

  5. JSON 之 SuperObject(5): Format 与转义字符

    unit Unit1; interface uses   Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, For ...

  6. VS2008下使用 CMFCPropertyGridCtrl 转载

    http://blog.csdn.net/sunnyloves/article/details/5655575 在DLG中的基本应用 . 首先在Cxxdlg.h文件中加入 public: CMFCPr ...

  7. Qt之等待提示框(QPropertyAnimation)

    简述 之前分享过QLabel可以通过QMovie播放gif图片,可以实现等待提示框,今天主要使用动画QPropertyAnimation来进行实现! 数据加载的时候,往往都需要后台线程进行数据请求,而 ...

  8. Chrome 快捷键使用

    窗口和标签页快捷方式 Ctrl+N 打开新窗口 按住 Ctrl‎ 键,然后点击链接 在新标签页中打开链接 按住 Shift 键,然后点击链接 在新窗口中打开链接 Alt+F4 关闭当前窗口 Ctrl+ ...

  9. file类型允许的文件格式设置问题,“选择文件”打开缓慢

    1,file类型的input对于打开的选择框的属性是由以下两个属性控制的: ①multiple="multiple" :一次可以选择多个文件 ②accept="image ...

  10. 几个排序算法的JS实现

    最近找工作,复习一下数据结构的知识,看到排序这一块,顺便动手改了一下. 直接插入排序: 插入排序就是把数据分为有序区和无序区,遍历到的数据和有序区域的数据进行比较,找到要插入的位置,插入位置后的数据做 ...