「NOI2014」购票 解题报告
「NOI2014」购票
写完了后发现写的做法是假的...然后居然过了,然后就懒得管正解了。
发现需要维护凸包,动态加点,询问区间,强制在线
可以二进制分组搞,然后你发现在树上需要资瓷撤回,然后暴力撤回(雾
然后就被卡了
卡法,在\(2^k-1\)位置搞一朵菊花
先留坑,以后要是会了一些神奇的姿势就来搞
这题叉积会爆ll,坑
Code:
#include <cstdio>
#include <cctype>
#include <vector>
#include <algorithm>
#define ll long long
const int N=2e5+10;
using std::min;
template <class T>
void read(T &x)
{
x=0;char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) x=x*10+c-'0',c=getchar();
}
int head[N],to[N],Next[N],cnt;ll edge[N];
int n,t;
void add(int u,int v,ll w)
{
to[++cnt]=v,edge[cnt]=w,Next[cnt]=head[u],head[u]=cnt;
}
struct Point
{
ll x,y;
Point(){}
Point(ll X,ll Y){x=X,y=Y;}
Point friend operator -(Point a,Point b){return Point(a.x-b.x,a.y-b.y);}
bool friend operator <(Point a,Point b){return a.x==b.x?a.y<b.y:a.x<b.x;}
};
long double Cross(Point a,Point b){return 1.0*a.x*b.y-1.0*a.y*b.x;}
std::vector<Point> s[N<<2],pot[N<<2],yuu;
void ins(int id,Point x)
{
int tot=s[id].size()-1;
while(tot>0&&Cross(s[id][tot]-s[id][tot-1],x-s[id][tot])<=0) --tot,s[id].pop_back();
s[id].push_back(x);
}
void build(int id)
{
yuu=pot[id];
std::sort(yuu.begin(),yuu.end());
s[id].clear();
for(int i=0;i<yuu.size();i++) ins(id,yuu[i]);
}
#define ls id<<1
#define rs id<<1|1
void add(int id,int l,int r,int p,Point ins)
{
pot[id].push_back(ins);
if(pot[id].size()==r+1-l) build(id);
if(l==r) return;
int mid=l+r>>1;
if(p<=mid) add(ls,l,mid,p,ins);
else add(rs,mid+1,r,p,ins);
}
void del(int id,int l,int r,int p)
{
pot[id].pop_back();
if(l==r) return;
int mid=l+r>>1;
if(p<=mid) del(ls,l,mid,p);
else del(rs,mid+1,r,p);
}
ll cal(Point a,ll k){return a.y-k*a.x;}
ll yuucute(int id,ll k)
{
int l=0,r=s[id].size()-1;
while(l<r)
{
int mid=l+r>>1;
if(cal(s[id][mid],k)>cal(s[id][mid+1],k)) l=mid+1;
else r=mid;
}
return cal(s[id][l],k);
}
ll query(int id,int L,int R,int l,int r,ll k)
{
if(l==L&&r==R) return yuucute(id,k);
int Mid=L+R>>1;
if(r<=Mid) return query(ls,L,Mid,l,r,k);
else if(l>Mid) return query(rs,Mid+1,R,l,r,k);
else return min(query(ls,L,Mid,l,Mid,k),query(rs,Mid+1,R,Mid+1,r,k));
}
int f[N][20],dep[N];ll fd[N][20];
int Find(int x,ll d)
{
for(int i=18;~i;i--)
if(fd[x][i]<=d)
d-=fd[x][i],x=f[x][i];
return dep[x];
}
ll ans[N],p[N],q[N],l[N];
void dfs(int now,ll d,int rp)
{
dep[now]=rp;
for(int i=1;i<=18;i++) f[now][i]=f[f[now][i-1]][i-1],fd[now][i]=fd[now][i-1]+fd[f[now][i-1]][i-1];
int lp=l[now]>=d?1:Find(now,l[now]);
ans[now]=query(1,1,n,lp,rp-1,p[now])+q[now]+d*p[now];
add(1,1,n,rp,Point(d,ans[now]));
for(int i=head[now];i;i=Next[i])
dfs(to[i],d+edge[i],rp+1);
del(1,1,n,rp);
}
int main()
{
read(n),read(t);
for(int i=2;i<=n;i++)
{
read(f[i][0]),read(fd[i][0]);
add(f[i][0],i,fd[i][0]);
read(p[i]),read(q[i]),read(l[i]);
}
add(1,1,n,1,Point(0,0));dep[1]=1;
for(int i=head[1];i;i=Next[i])
dfs(to[i],edge[i],2);
for(int i=2;i<=n;i++) printf("%lld\n",ans[i]);
return 0;
}
2019.2.22
「NOI2014」购票 解题报告的更多相关文章
- 「NOI2014」购票
「NOI2014」购票 解题思路 先列出 \(dp\) 式子并稍微转化一下 \[ dp[u] =\min(dp[v]+(dis[u]-dis[v]) \times p[u] + q[u])) \ \ ...
- 「ZJOI2016」旅行者 解题报告
「ZJOI2016」旅行者 对网格图进行分治. 每次从中间选一列,然后枚举每个这一列的格子作为起点跑最短路,进入子矩形时把询问划分一下,有点类似整体二分 至于复杂度么,我不会阿 Code: #incl ...
- 「HNOI2016」树 解题报告
「HNOI2016」树 事毒瘤题... 我一开始以为每次把大树的子树再接给大树,然后死活不知道咋做,心想怕不是个神仙题哦 然后看题解后才发现是把模板树的子树给大树,虽然思维上难度没啥了,但是还是很难写 ...
- 「HNOI2016」序列 解题报告
「HNOI2016」序列 有一些高妙的做法,懒得看 考虑莫队,考虑莫队咋移动区间 然后你在区间内部找一个最小值的位置,假设现在从右边加 最小值左边区间显然可以\(O(1)\),最小值右边的区间是断掉的 ...
- 「HNOI2016」网络 解题报告
「HNOI2016」网络 我有一个绝妙的可持久化树套树思路,可惜的是,它的空间是\(n\log^2 n\)的... 注意到对一个询问,我们可以二分答案 然后统计经过这个点大于当前答案的路径条数,如果这 ...
- 「HAOI2018」染色 解题报告
「HAOI2018」染色 是个套路题.. 考虑容斥 则恰好为\(k\)个颜色恰好为\(c\)次的贡献为 \[ \binom{m}{k}\sum_{i\ge k}(-1)^{i-k}\binom{m-k ...
- 「HNOI2016」最小公倍数 解题报告
「HNOI2016」最小公倍数 考虑暴力,对每个询问,处理出\(\le a,\le b\)的与询问点在一起的联通块,然后判断是否是一个联通块,且联通块\(a,b\)最大值是否满足要求. 然后很显然需要 ...
- 「SCOI2016」围棋 解题报告
「SCOI2016」围棋 打CF后困不拉基的,搞了一上午... 考虑直接状压棋子,然后发现会t 考虑我们需要上一行的状态本质上是某个位置为末尾是否可以匹配第一行的串 于是状态可以\(2^m\)压住了, ...
- 「SCOI2016」妖怪 解题报告
「SCOI2016」妖怪 玄妙...盲猜一个结论,然后过了,事后一证,然后假了,数据真水 首先要最小化 \[ \max_{i=1}^n (1+k)x_i+(1+\frac{1}{k})y_i \] \ ...
随机推荐
- js 移动端 多图上传 预览 删除 base64转为url 传给后端
说下主要的逻辑,首先是利用input type="file",上传文件,然后判断文件类型是否是图片,这里要注意(multiple,安卓一次一张,ios可以多张). 接着把本地图片转 ...
- 【学亮开讲】Oracle存储过程教学笔记(一)20181115
--创建业主序列起始值为11 ; --不带传出参数的存储过程 create or replace procedure pro_owners_add ( v_name varchar2,--名称 v_a ...
- 转:Flutter Decoration背景设定(边框、圆角、阴影、形状、渐变、背景图像等)
1 继续关系: BoxDecoration:实现边框.圆角.阴影.形状.渐变.背景图像 ShapeDecoration:实现四个边分别指定颜色和宽度.底部线.矩形边色.圆形边色.体育场(竖向椭圆). ...
- SpringBoot 4.SpringBoot 整合 devtools 实现热部署
一.添加 devtools 依赖 <!-- Spring boot 热部署 : 此热部署会遇到 java.lang.ClassCastException 异常 --> <!-- op ...
- Golang的方法传递值应该注意的地方
其实最近看了不少Golang接口以及方法的阐述都有一个地方没说得特别明白.就是在Golang编译隐式转换传递给方法使用的时候,和调用函数时的区别. 我们都知道,在我们为一个类型变量申明了一个方法的时候 ...
- PHP的爬虫框架
Beanbun PHPSpider PHPQuery QueryList PHPCrawer Snoopy
- 在delphi中生成GUID
什么是 GUID ? 全球唯一标识符 (GUID) 是一个字母数字标识符,用于指示产品的唯一性安装.在许多流行软件应用程序(例如 Web 浏览器和媒体播放器)中,都使用 GUID. GUID 的格式为 ...
- codeforces-962-c
题意:给你一个数,问从中删除某几位数字后重新组成的数字是否是某个数的平方: 解题思路:数据小,dfs直接搜,每位数只有两种选择,要或者不要 #include<iostream> #incl ...
- python命令里运行正确但是pycharm里面运行就是报错的问题
这两天在学习爬虫,第一步就是 import scrapy class StackOverflowSpider(scrapy.Spider): 结果一直报错,说是scrapy没有spider这个方法,各 ...
- 【转】微信小程序开发之图片等比例缩放 获取屏幕尺寸图片尺寸 自适应
原文[https://blog.csdn.net/qq_31383345/article/details/53127804] 早上在论坛上看到有人写了关于图片等比例缩放的文章,只是判断了图片宽是否大于 ...