http://uoj.ac/problem/7 (题目链接)

题意

  给出一棵有根树,每次从一个节点出发可以买票到达它的一定范围内的祖先。问对于每一个点,到达根的最小花费是多少。

Solution

  右转题解→_→:LCF

  一些细节自己YY一下就好,看看代码也行。

细节

  最好写读入优化?

代码

// uoj7
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define inf (1ll<<60)
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
using namespace std;
inline LL gi() {
LL x=0,f=1;char ch=getchar();
while (ch>'9' || ch<'0') {if (ch=='-') f=-1;ch=getchar();}
while (ch<='9' && ch>='0') {x=x*10+ch-'0';ch=getchar();}
return x*f;
} const int maxn=200010;
int n,T,cnt,a[maxn],par[maxn],head[maxn];
LL d[maxn],Q[maxn],P[maxn],L[maxn],ans[maxn]; struct node {LL w;int num;}t[maxn];
struct edge {int to,next;}e[maxn<<1]; namespace DP {
int l,r,q[maxn];
void Clear() {l=1,r=0;}
double slope(int i,int j) {
return (double)(ans[i]-ans[j])/(d[i]-d[j]);
}
void push(int x) {
while (l<r && slope(q[r-1],q[r])<slope(x,q[r])) r--;
q[++r]=x;
}
void update(int x) {
if (l>r) return;
int ll=l,rr=r,y;
while (ll<=rr) {
int mid=(ll+rr)>>1;
if (ll<mid && slope(q[mid-1],q[mid])<P[x]) y=mid,rr=mid-1;
else if (rr>mid && slope(q[mid],q[mid+1])>P[x]) y=mid,ll=mid+1;
else {y=mid;break;}
}
y=q[y];
ans[x]=min(ans[x],ans[y]+(d[x]-d[y])*P[x]+Q[x]);
}
}
using namespace DP; namespace NodeDivide {
int size[maxn],f[maxn],vis[maxn];
int Dargen,sum,dfn;
bool cmp(node a,node b) {
return a.w>b.w;
}
void caldargen(int x,int fa) {
size[x]=1;f[x]=0;
for (int i=head[x];i;i=e[i].next) if (e[i].to!=fa && !vis[e[i].to]) {
caldargen(e[i].to,x);
size[x]+=size[e[i].to];
f[x]=max(f[x],size[e[i].to]);
}
f[x]=max(f[x],sum-size[x]);
if (f[x]<f[Dargen]) Dargen=x;
}
void dfs(int x,int fa) {
a[++dfn]=x;
for (int i=head[x];i;i=e[i].next) if (e[i].to!=fa && !vis[e[i].to]) dfs(e[i].to,x);
}
void work(int x) {
vis[x]=1;
if (!vis[par[x]]) {
sum=size[par[x]];
Dargen=0;caldargen(par[x],x);
work(Dargen);
}
Clear();
for (int j=par[x];!vis[j] && d[x]-d[j]<=L[x];j=par[j]) push(j);
update(x);
dfn=0;
for (int i=head[x];i;i=e[i].next)
if (!vis[e[i].to] && e[i].to!=par[x]) dfs(e[i].to,x);
for (int i=1;i<=dfn;i++) t[i]=(node){d[a[i]]-L[a[i]],a[i]};
sort(t+1,t+1+dfn,cmp);
Clear();
for (int j=x,i=1;i<=dfn;i++) {
for (;(!vis[j] || j==x) && t[i].w<=d[j];j=par[j]) push(j);
update(t[i].num);
}
for (int i=head[x];i;i=e[i].next) if (e[i].to!=par[x] && !vis[e[i].to]) {
sum=size[e[i].to],Dargen=0;
caldargen(e[i].to,x);
work(Dargen);
}
vis[x]=0;
}
void Init() {
f[Dargen=0]=1<<30;
sum=n;vis[0]=1;
caldargen(1,0);
work(Dargen);
}
} void link(int u,int v) {
e[++cnt]=(edge){v,head[u]};head[u]=cnt;
e[++cnt]=(edge){u,head[v]};head[v]=cnt;
}
int main() {
n=gi(),T=gi();
for (int i=2;i<=n;i++) {
par[i]=gi(),d[i]=gi(),P[i]=gi(),Q[i]=gi(),L[i]=gi();
d[i]+=d[par[i]];ans[i]=inf;link(i,par[i]);
}
NodeDivide::Init();
for (int i=2;i<=n;i++) printf("%lld\n",ans[i]);
return 0;
}

【uoj7】 NOI2014—购票的更多相关文章

  1. BZOJ3672/UOJ7 [Noi2014]购票

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...

  2. [BZOJ3672][UOJ#7][NOI2014]购票

    [BZOJ3672][UOJ#7][NOI2014]购票 试题描述  今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国 n 个城市的OIer们都会从各地出发,到SZ市参加这次盛会.       ...

  3. bzoj 3672: [Noi2014]购票 树链剖分+维护凸包

    3672: [Noi2014]购票 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 480  Solved: 212[Submit][Status][D ...

  4. BZOJ 3672: [Noi2014]购票( 树链剖分 + 线段树 + 凸包 )

    s弄成前缀和(到根), dp(i) = min(dp(j) + (s(i)-s(j))*p(i)+q(i)). 链的情况大家都会做...就是用栈维护个下凸包, 插入时暴力弹栈, 查询时就在凸包上二分/ ...

  5. bzoj千题计划251:bzoj3672: [Noi2014]购票

    http://www.lydsy.com/JudgeOnline/problem.php?id=3672 法一:线段树维护可持久化单调队列维护凸包 斜率优化DP 设dp[i] 表示i号点到根节点的最少 ...

  6. [BZOJ3672][Noi2014]购票 斜率优化+点分治+cdq分治

    3672: [Noi2014]购票 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 1749  Solved: 885[Submit][Status][ ...

  7. [NOI2014]购票 --- 斜率优化 + 树形DP + 数据结构

    [NOI2014]购票 题目描述 今年夏天,NOI在SZ市迎来了她30周岁的生日. 来自全国 n 个城市的OIer们都会从各地出发,到SZ市参加这次盛会. 全国的城市构成了一棵以SZ市为根的有根树,每 ...

  8. 【BZOJ 3672】 3672: [Noi2014]购票 (CDQ分治+点分治+斜率优化)**

    3672: [Noi2014]购票 Description  今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国 n 个城市的OIer们都会从各地出发,到SZ市参加这次盛会.        全国 ...

  9. 【BZOJ3672】[Noi2014]购票 树分治+斜率优化

    [BZOJ3672][Noi2014]购票 Description  今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国 n 个城市的OIer们都会从各地出发,到SZ市参加这次盛会.       ...

  10. BZOJ_3672_ [Noi2014]购票_CDQ分治+斜率优化

    BZOJ_3672_ [Noi2014]购票_CDQ分治+斜率优化 Description  今年夏天,NOI在SZ市迎来了她30周岁的生日.来自全国 n 个城市的OIer们都会从各地出发,到SZ市参 ...

随机推荐

  1. 有关java(初学笔记)

    JAVA的主要优势:跨平台性,可以在Linux,windows,mac三个系统上运行. 跨平台的核心:JAVA虚拟机--JVM 原理就是将Java语言在这个系统上翻译.JAVA在jvm上运行,jvm进 ...

  2. 大数据入门第二十四天——SparkStreaming(一)入门与示例

    一.概述 1.什么是spark streaming Spark Streaming is an extension of the core Spark API that enables scalabl ...

  3. 20155204《网络对抗》Exp 6 信息搜集与漏洞扫描

    20155204<网络对抗>Exp 6 信息搜集与漏洞扫描 一.实验后回答问题 1.哪些组织负责DNS,IP的管理. 互联网名称与数字地址分配机构,简称ICANN机构,决定了域名和IP地址 ...

  4. Exp4 恶意代码分析 20155223

    Exp4 恶意代码分析 20155223 使用原生命令schtasks监视系统运行 在系统盘目录下建立脚本文件netstatlog.bat,包含以下命令: date /t >> c:\ne ...

  5. 20155305《网络对抗》PC平台逆向破解(二)

    20155305<网络对抗>PC平台逆向破解(二) shellcode注入 1.shellcode shellcode是一段代码,溢出后,执行这段代码能开启系统shell. 2.构造方法 ...

  6. 微信小程序之授权 wx.authorize

    一. wx.authorize(Object object) 提前向用户发起授权请求.调用后会立刻弹窗询问用户是否同意授权小程序使用某项功能或获取用户的某些数据,但不会实际调用对应接口.如果用户之前已 ...

  7. fastDFS教程Ⅱ-文件服务器迁移

    在实际的项目应用中,由于服务器替换或项目变更难免会存在fastDFS文件服务器迁移的工作.本文重点介绍fastDFS文件系统在不同情况下的文件迁移处理方案. 1.迁移时IP地址不变 通过文件服务器存储 ...

  8. 金蝶盘点机PDA仓库条码管理:仓库如何盘点

    1.1. 仓库盘点 传统的仓库盘点,需要人工手工抄写盘点单,时候再去电脑上一行行的录入盘点单,操作非常耗时费力,往往需要盘点好几天,最终盘点效果还不好,在抄写过程中容易出现错误,从而造成盘点结果不准确 ...

  9. 《Pro SQL Server Internals, 2nd edition》中CHAPTER 7 Designing and Tuning the Indexes中的Clustered Index Design Considerations一节(译)

    <Pro SQL Server Internals> 作者: Dmitri Korotkevitch 出版社: Apress出版年: 2016-12-29页数: 804定价: USD 59 ...

  10. 《Deep Learning》(深度学习)中文版PDF免费下载

    <Deep Learning>(深度学习)中文版PDF免费下载 "深度学习"经典著作<Deep Learning>中文版pdf免费下载. <Deep ...