bzoj 3611: [Heoi2014]大工程
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define M 2000009
#define inf 0x7ffffff
#define ll long long
using namespace std;
int n,head[M],next[M],u[M],cnt,head1[M],next1[M],u1[M],fa[M][],deep[M],m,dfn[M],T,v[M];
int h[M],st[M],mn[M],mx[M],size[M],mx1,mi1,v1[M];
ll cn1,sum[M];
void jia(int a1,int a2)
{
cnt++;
next[cnt]=head[a1];
head[a1]=cnt;
u[cnt]=a2;
return;
}
void jia2(int a1,int a2)
{
if(a1==a2)
return;
cnt++;
next1[cnt]=head1[a1];
head1[a1]=cnt;
u1[cnt]=a2;
v1[cnt]=deep[a2]-deep[a1];
return;
}
bool cmp(int a1,int a2)
{
return dfn[a1]<dfn[a2];
}
void dfs(int a1)
{
dfn[a1]=++T;
for(int i=;(<<i)<=deep[a1];i++)
fa[a1][i]=fa[fa[a1][i-]][i-];
for(int i=head[a1];i;i=next[i])
if(fa[a1][]!=u[i])
{
deep[u[i]]=deep[a1]+;
fa[u[i]][]=a1;
dfs(u[i]);
}
return;
}
int lca(int a1,int a2)
{
if(deep[a1]<deep[a2])
swap(a1,a2);
int a3=deep[a1]-deep[a2];
for(int i=;i<=;i++)
if(a3&(<<i))
a1=fa[a1][i];
for(int i=;i>=;i--)
if(fa[a1][i]!=fa[a2][i])
{
a1=fa[a1][i];
a2=fa[a2][i];
}
if(a1==a2)
return a1;
return fa[a1][];
}
void dp(int x){
sum[x]=;
mx[x]=v[x]?:-inf;
mn[x]=v[x]?:inf;
size[x]=v[x];
for(int i=head1[x];i;i=next1[i]){
int v=u1[i];
dp(v);
cn1+=(sum[x]+size[x]*v1[i])*size[v]+size[x]*sum[v];
size[x]+=size[v];
sum[x]+=sum[v]+(ll)size[v]*v1[i];
mi1=min(mi1,mn[v]+mn[x]+v1[i]);
mx1=max(mx1,mx[v]+mx[x]+v1[i]);
mn[x]=min(mn[x],mn[v]+v1[i]);
mx[x]=max(mx[x],mx[v]+v1[i]);
}
head1[x]=;
}
void solve(){
cnt=cn1=;mi1=inf;mx1=-inf;
int K;
scanf("%d",&K);
for(int i=;i<=K;i++) scanf("%d",&h[i]),v[h[i]]=;
sort(h+,h+K+,cmp);int top=;st[]=;
for(int i=;i<=K;i++){
int now=h[i],f=lca(st[top],now);
if(dfn[f]==dfn[st[top]]) st[++top]=now;
else{
while(top){
int q=st[top-];
if(dfn[q]>dfn[f]) jia2(st[top-],st[top]),top--;
else if(dfn[q]==dfn[f]){
jia2(q,st[top]);top--;break;
}
else {
jia2(f,st[top]);st[top]=f;break;
}
}
if(st[top]!=now) st[++top]=now;
}
}
while(--top)jia2(st[top],st[top+]);
dp();
printf("%lld ",cn1);
printf("%d %d\n",mi1,mx1);
for(int i=;i<=K;i++) v[h[i]]=;
}
int main()
{
scanf("%d",&n);
for(int i=;i<n;i++)
{
int a1,a2;
scanf("%d%d",&a1,&a2);
jia(a1,a2);
jia(a2,a1);
}
dfs();
scanf("%d",&m);
for(int i=;i<=m;i++)
solve();
return ;
}
虚树,树形DP
bzoj 3611: [Heoi2014]大工程的更多相关文章
- bzoj 3611 [Heoi2014]大工程(虚树+DP)
3611: [Heoi2014]大工程 Time Limit: 60 Sec Memory Limit: 512 MBSubmit: 408 Solved: 190[Submit][Status] ...
- bzoj 3611: [Heoi2014]大工程 && bzoj 2286: [Sdoi2011消耗战
放波建虚树的模板. 大概是用一个栈维护根节点到当前关键点的一条链,把其他深度大于lca的都弹出去. 每次做完记得复原. 还有sort的时候一定要加cmp!!! bzoj 3611 #include&l ...
- bzoj 3611: [Heoi2014]大工程 虚树
题目: 国家有一个大工程,要给一个非常大的交通网络里建一些新的通道. 我们这个国家位置非常特殊,可以看成是一个单位边权的树,城市位于顶点上. 在 2 个国家 a,b 之间建一条新通道需要的代价为树上 ...
- bzoj 3611[Heoi2014]大工程 虚树+dp
题意: 给一棵树 每次选 k 个关键点,然后在它们两两之间 新建 C(k,2)条 新通道. 求: 1.这些新通道的代价和 2.这些新通道中代价最小的是多少 3.这些新通道中代价最大的是多少 分析:较常 ...
- BZOJ.3611.[HEOI2014]大工程(虚树 树形DP)
题目链接 要求的和.最大值.最小值好像都可以通过O(n)的树形DP做,总询问点数<=2n. 于是建虚树就可以了.具体DP见DP()函数,维护三个值sum[],mx[],mn[]. sum[]要开 ...
- BZOJ 3611 [Heoi2014]大工程 ——虚树
虚树第二题.... 同BZOJ2286 #include <map> #include <cmath> #include <queue> #include < ...
- 3611: [Heoi2014]大工程
3611: [Heoi2014]大工程 链接 分析: 树形dp+虚树. 首先建立虚树,在虚树上dp. dp:sum[i]为i的子树中所有询问点之间的和.siz[i]为i的子树中有多少询问点,mn[i] ...
- BZOJ2286 [Sdoi2011]消耗战 和 BZOJ3611 [Heoi2014]大工程
2286: [Sdoi2011]消耗战 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6371 Solved: 2496[Submit][Statu ...
- [Bzoj3611][Heoi2014]大工程(虚树)
3611: [Heoi2014]大工程 Time Limit: 60 Sec Memory Limit: 512 MBSubmit: 2000 Solved: 837[Submit][Status ...
随机推荐
- SVN服务器搭建和使用(二)
SVN服务器搭建和使用(二) 上一篇介绍了VisualSVN Server和TortoiseSVN的下载,安装,汉化.这篇介绍一下如何使用VisualSVN Server建立版本库,以及Tortois ...
- [转]使用Stopwatch类实现高精度计时
对一段代码计时同查通常有三种方法.最简单就是用DateTime.Now来进行比较了,不过其精度只有3.3毫秒,可以通过DllImport导入QueryPerformanceFrequency和Quer ...
- Spring MVC中Action使用总结
Spring MVC中每个控制器中可以定义多个请求处理方法即Action,Action可以有多个不同的参数,有多种类型的返回结果. 可以作为Action的参数类型有: 表单对象基本数据类型,包括包装类 ...
- U盘插入电脑后,提示需要格式化U盘如何解决?
未弹出U盘就拔掉U盘,有可能会破坏U盘的分区表.当再次把U盘插入电脑时,会提示需要格式化U盘,这是什么情况,如何解决呢?其实只要用DiskGenius硬盘恢复软件就可以解决这个问题.下面和小编一起来看 ...
- background-sizi (转)
http://www.cnblogs.com/greenteaone/archive/2012/08/28/2659878.html (原创作者链接地址 ) Background-Size:[ & ...
- 详解MVC设计模式
1 MVC介绍 众所周知MVC不是设计模式,是一个比设计模式更大一点的模式,称作设计模式不合理,应该说MVC它是一种软件开发架构模式,它包含了很多的设计模式,最为密切是以下三种:Observer (观 ...
- ie6、7下 text-indent 问题
text-indent属性 用于文字缩进,更多是用来隐藏文字.比如,一个logo标题,上面的问题很有艺术感,不得不把文字和背景组合成一张背景图(此处页面元素用a表示),但处于SEO方面的考虑,需要把a ...
- 漂亮的Linux命令提示符
漂亮的Linux命令提示符 每天面对着白底黑字(黑底白字)的命令行是否枯燥泛味呢?生活应给是五彩缤纷的,何不为单调无味的生活增添一抹色彩? 下面一起体验一下Linux命令行提示符惊险的整容之旅 惊鸿一 ...
- RESTFUL API 安全设计指南
RESTFUL API 安全设计指南 xxlegend · 2015/10/18 15:08 0x01 REST API 简介 REST的全称是REpresentational State Trans ...
- MySQL 语句使用到的关键字 函数 记录
一 处理重复数据 1 使用 UNIQUE 唯一键 (添加数据) 创建表的时候设置 2 使用 DISTINCT (查询数据--过滤) eg:SELECT DISTINCT `name` from ...