题目

P4103 [HEOI2014]大工程

化简题目:在树上选定\(k\)个点,求两两路径和,最大的一组路径,最小的一组路径

做法

关键点不多,建个虚树跑一边就好了

\(sum_i\)为\(i\)子树各关键点到根节点的距离和,\(small_i\)为其最小值,\(big_i\)为其最大值

My complete code

#include<cstdio>
#include<iostream>
#include<cstring>
#include<string>
#include<algorithm>
#include<vector>
using namespace std;
typedef long long LL;
inline LL Read(){
LL x(0),f(1); char c=getchar();
while(c<'0'||c>'9'){
if(c=='-')f=-1; c=getchar();
}
while(c>='0'&&c<='9')
x=(x<<3)+(x<<1)+c-'0',c=getchar();
return x*f;
}
const LL maxn=2*1e6+9,inf=0x3f3f3f3f;
LL n,ans1,ans2,ans3;
LL a[maxn],sta[maxn];
struct Tree{
LL tot,num,head[maxn],dfn[maxn],dep[maxn],size[maxn],key[maxn],inc[maxn][25],fa[maxn];
LL sum[maxn],big[maxn],small[maxn];
struct node{
LL to,next,d;
}dis[maxn];
inline void Add(LL u,LL v,LL d){
dis[++num]=(node){v,head[u],d},head[u]=num;
}
void Fdfs(LL u){
dfn[u]=++tot;
inc[u][0]=fa[u];
for(LL i=1;i<=21;++i)
inc[u][i]=inc[inc[u][i-1]][i-1];
for(LL i=head[u];i;i=dis[i].next){
LL v(dis[i].to);
if(v==fa[u])
continue;
fa[v]=u,dep[v]=dep[u]+1,
Fdfs(v);
}
}
inline LL Lca(LL x,LL y){
if(dep[x]<dep[y])
swap(x,y);
for(LL i=20;i>=0;--i)
if(dep[inc[x][i]]>=dep[y])
x=inc[x][i];
if(x==y)
return x;
for(LL i=20;i>=0;--i)
if(inc[x][i]!=inc[y][i])
x=inc[x][i],y=inc[y][i];
return inc[x][0];
}
void Dfs(LL u){
size[u]=key[u],
sum[u]=big[u]=0,
small[u]=(key[u]==0)?inf:0;
for(LL i=head[u];i;i=dis[i].next){
LL v(dis[i].to),d(dis[i].d);
Dfs(v);
if(size[u]){
ans1+=size[u]*size[v]*d+size[u]*sum[v]+size[v]*sum[u],
ans2=min(ans2,small[u]+d+small[v]),
ans3=max(ans3,big[u]+d+big[v]);
}
sum[u]+=sum[v]+size[v]*d;
small[u]=min(small[u],small[v]+d),
big[u]=max(big[u],big[v]+d),
size[u]+=size[v];
}
head[u]=key[u]=0;
}
}T,X;
inline bool cmp1(LL x,LL y){
return T.dfn[x]<T.dfn[y];
}
inline void Solve(){
LL kase=Read();
while(kase--){
LL num(Read());
for(LL i=1;i<=num;++i)
a[i]=Read();
sort(a+1,a+1+num,cmp1);
LL tp; sta[tp=1]=1;
for(LL i=1;i<=num;++i){
X.key[a[i]]=1;
LL lca=T.Lca(a[i],sta[tp]);
while(T.dep[sta[tp]]>T.dep[lca])
if(T.dep[sta[tp-1]]<T.dep[lca])
X.Add(lca,sta[tp],T.dep[sta[tp]]-T.dep[lca]),sta[tp]=lca;
else
X.Add(sta[tp-1],sta[tp],T.dep[sta[tp]]-T.dep[sta[tp-1]]),--tp;
if(sta[tp]!=a[i])
sta[++tp]=a[i];
}
while(tp>1)
X.Add(sta[tp-1],sta[tp],T.dep[sta[tp]]-T.dep[sta[tp-1]]),--tp;
ans1=0,ans2=inf,ans3=0;
X.Dfs(1);
printf("%lld %lld %lld\n",ans1,ans2,ans3);
}
}
int main(){
n=Read();
for(LL i=1;i<n;++i){
LL u(Read()),v(Read());
T.Add(u,v,1),T.Add(v,u,1);
}
T.Fdfs(1);
Solve();
return 0;
}/*
*/

P4103 [HEOI2014]大工程的更多相关文章

  1. luogu P4103 [HEOI2014]大工程 虚树 + 树形 DP

    Description 国家有一个大工程,要给一个非常大的交通网络里建一些新的通道.  我们这个国家位置非常特殊,可以看成是一个单位边权的树,城市位于顶点上.  在 2 个国家 a,b 之间建一条新通 ...

  2. 洛谷P4103 [HEOI2014]大工程(虚树 树形dp)

    题意 链接 Sol 虚树. 首先建出虚树,然后直接树形dp就行了. 最大最小值直接维护子树内到该节点的最大值,然后合并两棵子树的时候更新一下答案. 任意两点的路径和可以考虑每条边两边的贡献,\(d[x ...

  3. [BZOJ3611][Heoi2014]大工程

    [BZOJ3611][Heoi2014]大工程 试题描述 国家有一个大工程,要给一个非常大的交通网络里建一些新的通道.  我们这个国家位置非常特殊,可以看成是一个单位边权的树,城市位于顶点上.  在 ...

  4. bzoj 3611 [Heoi2014]大工程(虚树+DP)

    3611: [Heoi2014]大工程 Time Limit: 60 Sec  Memory Limit: 512 MBSubmit: 408  Solved: 190[Submit][Status] ...

  5. 【LG4103】[HEOI2014]大工程

    [LG4103][HEOI2014]大工程 题面 洛谷 题解 先建虚树,下面所有讨论均是在虚树上的. 对于第一问:直接统计所有树边对答案的贡献即可. 对于第\(2,3\)问:记\(f[x]\)表示在\ ...

  6. 3611: [Heoi2014]大工程

    3611: [Heoi2014]大工程 链接 分析: 树形dp+虚树. 首先建立虚树,在虚树上dp. dp:sum[i]为i的子树中所有询问点之间的和.siz[i]为i的子树中有多少询问点,mn[i] ...

  7. BZOJ2286 [Sdoi2011]消耗战 和 BZOJ3611 [Heoi2014]大工程

    2286: [Sdoi2011]消耗战 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6371  Solved: 2496[Submit][Statu ...

  8. 【BZOJ3611】[Heoi2014]大工程 欧拉序+ST表+单调栈

    [BZOJ3611][Heoi2014]大工程 Description 国家有一个大工程,要给一个非常大的交通网络里建一些新的通道.  我们这个国家位置非常特殊,可以看成是一个单位边权的树,城市位于顶 ...

  9. [Bzoj3611][Heoi2014]大工程(虚树)

    3611: [Heoi2014]大工程 Time Limit: 60 Sec  Memory Limit: 512 MBSubmit: 2000  Solved: 837[Submit][Status ...

随机推荐

  1. java如何实现多个线程并发运行

    随着计算机技术的发展,编程模型也越来越复杂多样化.但多线程编程模型是目前计算机系统架构的最终模型.随着CPU主频的不断攀升,X86架构的硬件已经成为瓶,在这种架构的CPU主频最高为4G.事实上目前3. ...

  2. 分享牛人就是的volatilekeyword

    volatile作用 一个定义为volatile的变量是说这变量可能会被意想不到地改变.这样,编译器就不会去如果这个变量的值了. 精确地说就是.优化器在用到这个变量时必须每次都小心地又一次读取这个变量 ...

  3. 查看系统启动内核检測硬件信息dmesg

    dmesg用来显示开机信息.kernel会将开机信息存储在ring buffer中.您若是开机时来不及查看信息,可利用dmesg来查看.开机信息亦保存在/var/log文件夹中.名称为dmesg的文件 ...

  4. Crashing Robots - poj 2632

      Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8352   Accepted: 3613 Description In ...

  5. Weblogic配置故障转移

    前提:实现负载均衡,即当访问项目时,会通过代理服务器将请求分发到不同的服务器上. weblogic的故障转移配置 在项目的WEB-INF目录下创建weblogic.xml <!DOCTYPE w ...

  6. RecyclerView 必知必会(转)

    [腾讯Bugly干货分享]RecyclerView 必知必会 本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:http://mp.weixin.qq.com ...

  7. shell 遍历所有文件包括子目录

    1.代码简单,但是难在校验,不像python那么好理解 建议在Notepad++下编辑. 2.注意引用linux命令的`是[tab]键上面那个 3.if[] 这里 Error :  syntax er ...

  8. web安全之SQL注入---第四章 如何进行SQL注入攻击

    第四章 如何进行SQL注入攻击1.数字注入2.字符串注入    '#    '--

  9. jquery 与javascript关系 ①取元素 ②操作内容 ③操作属性 ④操作 样式 ⑤ 事件 点击变色

    jQuery的min版本和原版功能是一样的,min版主要应用于已经开发成的网页中,而非min版 的文件比较大,里面有整洁的代码书写规范和注释,主要应用于脚本开发过程当中. JQuery是继protot ...

  10. GitHub从无到有

    一步一步教你如何在GitHub上上传自己的项目 2018年07月04日 09:23:40 夏雨薇安 阅读数:22764   首先你得注册一个自己的GitHub账号,注册网址:https://githu ...