bzoj 3672 购票 点分治+dp
3672: [Noi2014]购票
Time Limit: 30 Sec Memory Limit: 512 MB
Submit: 1177 Solved: 562
[Submit][Status][Discuss]
Description
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cstdlib>
#define ll long long
#define inf 1e17
#define N 200005
using namespace std;
int n,t;
int head[N],ver[N*2],nxt[N*2],tot;
ll quan[N*2];
void add(int a,int b,ll c)
{
tot++;nxt[tot]=head[a];head[a]=tot;ver[tot]=b;quan[tot]=c;return ;
}
int fa[N],d[N];
ll s[N],p[N],q[N],l[N],dep[N],f[N];
void dfs(int x,int ff)
{
for(int i=head[x];i;i=nxt[i])
{
if(ver[i]==ff)continue;
dep[ver[i]]=dep[x]+quan[i];
d[ver[i]]=d[x]+1;
dfs(ver[i],x);
}
return ;
}
int mn,zhong;
int size[N],now,v[N];
void dffs(int x,int ff)
{
int mx=0;size[x]=1;
for(int i=head[x];i;i=nxt[i])
{
if(v[ver[i]]||ver[i]==ff)continue;
dffs(ver[i],x);
size[x]+=size[ver[i]];
if(size[ver[i]]>mx)mx=size[ver[i]];
}if(now-size[x]>mx)mx=now-size[x];
if(mx<mn)mn=mx,zhong=x;
return ;
}
int tp[N],top;
void dfss(int x,int ff)
{
for(int i=head[x];i;i=nxt[i])
{
if(v[ver[i]]||ver[i]==ff)continue;
tp[++top]=ver[i];
dfss(ver[i],x);
}
}
bool cmp(int x,int y)
{
return dep[x]-l[x]>dep[y]-l[y];
}
int g[N];int as[N],cnt;
double cj(ll x,ll y,ll xx,ll yy)
{
return (double)x*yy-(double)y*xx;
}
double xie[N];
void dp()
{
int pt=1;int r=0;
for(int i=1;i<=top;i++)
{
int x=tp[i];
while(pt!=cnt+1&&dep[x]-l[x]<=dep[as[pt]])
{
while(r>1&&cj(dep[as[g[r]]]-dep[as[pt]],f[as[g[r]]]-f[as[pt]],dep[as[g[r-1]]]-dep[as[pt]],f[as[g[r-1]]]-f[as[pt]])<=0)r--;
g[++r]=pt;
if(r!=1)xie[r]=(double)(f[as[pt]]-f[as[g[r-1]]])/(double)(dep[as[pt]]-dep[as[g[r-1]]]);
pt++;
}xie[1]=1e100;
if(!r)continue;
int ha=1,ta=r;
while(ha<=ta)
{
int mid=(ha+ta)>>1;
if(xie[mid]>=p[x])ha=mid+1;
else ta=mid-1;
}
f[x]=min(f[x],f[as[g[ta]]]+(dep[x]-dep[as[g[ta]]])*p[x]+q[x]);
}
}
int id;
void ds(int x,int ff)
{
size[x]=1;if(d[x]<mn)mn=d[x],id=x;
for(int i=head[x];i;i=nxt[i])
{
if(ver[i]==ff||v[ver[i]])continue;
ds(ver[i],x);
size[x]+=size[ver[i]];
}
}
void solve(int x)
{
now=size[x];mn=n+1;zhong=x;
dffs(x,-1);
int root=zhong;v[root]=1;mn=n+1;
ds(root,-1);int pp=id;
for(int i=head[root];i;i=nxt[i])
{
if(!v[ver[i]]&&ver[i]==fa[root])solve(ver[i]);
}
cnt=0;as[++cnt]=root;
for(int i=fa[root];i!=fa[pp];i=fa[i])
{
as[++cnt]=i;
if(dep[root]-dep[i]<=l[root])f[root]=min(f[root],f[i]+(dep[root]-dep[i])*p[root]+q[root]);
}
top=0;
dfss(root,-1);
sort(tp+1,tp+top+1,cmp);
dp();
for(int i=head[root];i;i=nxt[i])
{
if(!v[ver[i]])solve(ver[i]);
}
return ;
}
int main()
{
scanf("%d%d",&n,&t);
for(int i=2;i<=n;i++)
{
scanf("%d%lld%lld%lld%lld",&fa[i],&s[i],&p[i],&q[i],&l[i]);
add(fa[i],i,s[i]);add(i,fa[i],s[i]);
}
for(int i=2;i<=n;i++)f[i]=inf;
d[1]=1;dfs(1,-1);
size[1]=n;solve(1);
for(int i=2;i<=n;i++)
{
printf("%lld\n",f[i]);
}
return 0;
}
bzoj 3672 购票 点分治+dp的更多相关文章
- BZOJ 3672 购票
Description 今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国\(n\)个城市的OIer们都会从各地出发,到SZ市参加这次盛会. 全国的城市构成了一棵以SZ市为根的有根树,每个城市与 ...
- [BZOJ]3672 购票(Noi2014)
革命尚未成功,同志还需努力. Description 今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国 n 个城市的OIer们都会从各地出发,到SZ市参加这次盛会. 全国的城市构成了一棵以SZ ...
- bzoj 3672 利用点分治将CDQ分治推广到树型结构上
最大的收获就是题目所说. deal(s) : 处理节点s所在块的问题,并保证: 1.s是该块中最靠近根节点的点,没有之一. 2.s所在块到根节点的路径上的点全都用来更新过了s所在块的所有节点. 然后步 ...
- ●BZOJ 3672 [Noi2014]购票
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3672 题解: 斜率优化DP,点分治(树上CDQ分治...) 这里有一个没有距离限制的简单版: ...
- BZOJ 3672[NOI2014]购票(树链剖分+线段树维护凸包+斜率优化) + BZOJ 2402 陶陶的难题II (树链剖分+线段树维护凸包+分数规划+斜率优化)
前言 刚开始看着两道题感觉头皮发麻,后来看看题解,发现挺好理解,只是代码有点长. BZOJ 3672[NOI2014]购票 中文题面,题意略: BZOJ 3672[NOI2014]购票 设f(i)f( ...
- BZOJ 4518 [Sdoi2016]征途(分治DP)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4518 [题目大意] 给出一个数列,分成m段,求方差最小,答案乘上m的平方. [题解] ...
- BZOJ_3672_ [Noi2014]购票_CDQ分治+斜率优化
BZOJ_3672_ [Noi2014]购票_CDQ分治+斜率优化 Description 今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国 n 个城市的OIer们都会从各地出发,到SZ市参 ...
- [BZOJ 4332] [JSOI2012]分零食(DP+FFT)
[BZOJ 4332] [JSOI2012]分零食(DP+FFT) 题面 同学们依次排成了一列,其中有A位小朋友,有三个共同的欢乐系数O,S和U.如果有一位小朋友得到了x个糖果,那么她的欢乐程度就是\ ...
- HDU 3507 Print Article(CDQ分治+分治DP)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=3507 [题目大意] 将长度为n的数列分段,最小化每段和的平方和. [题解] 根据题目很容易得到dp ...
随机推荐
- Windows下LimeSDR Mini使用说明
本文内容.开发板及配件仅限用于学校或科研院所开展科研实验! 淘宝店铺名称:开源SDR实验室 LimeSDR链接:https://item.taobao.com/item.htm?spm=a230r.1 ...
- 用EXCEL批量更改文件名,一个命令就能完成
工作任务:学籍库里需要更新和完善学生信息,其中有一项工作就是要导入以身份证号为文件名的学生照片,而目前各个班级提交的学生照片是以学生姓名命名的.如何将学生姓名批量转换成身份证号码呢? 解决方案:用EX ...
- 笨办法学Python - 习题11-12: Asking Questions & Prompting People
目录 1.习题 11: 提问 2.习题 12: 提示别人 3.总结 1.习题 11: 提问 学习目标:了解人机交互场景,熟悉raw_input 的用法. 1.在 Python2.x 中 raw_inp ...
- linux 常用反弹shell小记
在渗透测试过程中由于防火墙和其它安全防御措施,很多服务器只能单向向外访问,不能被访问,我们常常需要反弹shell. 1.bash反弹shell 本地开启监听 nc -lvvp 受害主机命令 bash ...
- Django_缓存
目录 Django缓存的介绍 配置(settings.py设置不同缓存介质) 应用(全局.视图函数.模板) 实测 Django缓存的介绍 除了Django这个web框架之外.其他框架都没有缓存.Dja ...
- Daily Scrum 11.15
今日完成任务: 1.在回答页面显示用户的相关信息 2.重写了搜索方法,并在自己的Demo网站测试成功 3.修改问题实体属性,加入悬赏积分:并在问题列表页面显示问题悬赏分数 遇到困难:一个是对于学长的搜 ...
- 20172325 2016-2017-2 《Java程序设计》第四周学习总结
20172325 2016-2017-2 <Java程序设计>第四周学习总结 教材学习内容总结 1.对类.对象.声明变量的定义和属性有了进一步的了解 2.学会如何编写一个类并运用到需要的程 ...
- 进阶系列(2)—— C#集合
一.集合介绍 集合是.NET FCL(Framework Class Library)的重要组成部分,我们平常撸C#代码时免不了和集合打交道,FCL提供了丰富易用的集合类型,给我们撸码提供了极大的便利 ...
- 实验二 四则运算 完成版 ver.1
package size; import java.awt.EventQueue; import javax.swing.JFrame; import javax.swing.JMenuBar; im ...
- 注册表:DWORD
百度百科 DWORD全称Double Word,是指注册表的键值,每个word为2个字节的长度,DWORD 双字即为4个字节,每个字节是8位,共32位. 在键值项窗口空白处单击右键,选择“新建”菜单项 ...