[洛谷U22158]策划体验(树上斜率优化)(二分最优决策)
题目背景
OL不在,Clao又在肝少*前线,他虽然觉得这个游戏的地图很烦,但是他认为地图的难度还是太低了,习习中作为策划还不够FM,于是他自己YY了一种新的地图和新的机制;
题目描述
整个地图呈树形结构,共有N+1 个节点,0 号节点为树的根节点,并且,与0 号节点相连的就只有1 号节点,除0 号节点外的所有节点上都会有一队战斗力为V_i的敌人存在;
指挥部设在0 号节点,玩家的操纵梯队只能出生在该节点,并且在进入地图时玩家将选择任意一个节点作为本次任务的终点,设为E ,玩家只需要将根节点到EE 节点这条链上的敌人全数消灭就能获得胜利;
每次任务玩家能够选择分成若干个回合完成,每个回合玩家可以使用计划模式功能选择前进多少步,把本回合能够到达的节点组成的集合记为S ,每个回合玩家还需从S 中选择一个节点作为基准节点,将该节点上敌人的战斗力记为A ,把S 中所有战斗力为A 的敌人总数(包括基准节点)记为B ,回合结束时玩家将获得A*B^2的额外经验;
为了防止玩家利用这个机制快速练级,Clao想知道每个节点作为终点时能获得的最多的经验值是多少以便于调整地图难度;由于他抽皮肤把脑子抽坏了,所以请你帮他解决这个问题;
输入输出格式
输入格式:
第一行一个整数N(N<=2e5) ,第二行N 个整数V_i(V_i<=1e4) ,接下来N-1 行每行一个整数F_i(0<=F_i<=N-1) 表示1 ~N 号节点分别对应的父亲(1 号节点的父亲保证为0 且没有其他节点的父亲为0 );
输出格式:
仅一行,N 个数分别表示以1 ~N 号节点作为任务结束节点时可以获得的最多的额外经验;
输入输出样例
说明
N<=200000,V_i<=10000
样例说明
设每次选择集合为S,基点为a,一次回合记为(S,a)
一号结点为终点时选择为((0,1),1);
二号结点为终点时选择集合为((0,1,2),1)
三号结点为终点时选择集合为((0,1,2),1), ((3),3)
四号结点为终点时选择集合为((0,1,2,3,4),1)
五号结点为终点时选择集合为((0,1,2,3,4),1)((5),5)
数据范围:
对于%5数据满足除0号点图为一条链vi<=5
对于%5数据满足除0号点图为两条链
对于%5数据满足除0号点图为三条链
对于%5数据满足除0号点图为四条链
对于%5数据满足除0号点图为五条链
对于%5数据满足除0号点图为五条链
对于%5数据满足除0号点图为六条链
对于%5数据满足除0号点图为七条链
对于%5数据满足除0号点图为八条链
对于%5数据满足除0号点图为九条链
对于%50的数据满足深度<=50
分析:
不会斜率优化的学学斜率优化:https://www.cnblogs.com/MashiroSky/p/6009685.html
题目是jsoi2011柠檬的强化版,那道题就是个二分斜率优化,详情:https://www.cnblogs.com/GXZlegend/p/8615607.html。
但那道题是只有一个询问,这道题是在树上,不可能每次暴力去做一次那道题的做法(后50分可以)
然后对于树上斜率优化看看我另外一篇博客的讲解博客的讲解博客的讲解http://www.cnblogs.com/lzdhydzzh/p/8622581.html
我也不知道讲的清楚不,不清楚网上搜搜?
AC代码:
# include <iostream>
# include <cstdio>
# include <cstring>
# include <algorithm>
using namespace std;
const int N = 2e5 + ;
const int M = 1e4 + ;
typedef long long LL;
int n,dt,head[N],p,t[M],fa[N],a[N],b[N],st[M],que[N],cnt[M];
int qpos[N],pos[N],qtop[N],tot;
LL s[N],f[N];
struct Edge{
int to,nex;
}edge[N];
void AddEdge(int u,int v)
{
edge[++p] = (Edge){v,head[u]};
head[u] = p;
}
LL mu2(LL x){return x * x;}
LL y(int i){return f[fa[i]] + mu2(s[i] - ) * a[i];}
LL x(int i){return * (s[i] - );}
LL Get(int A,int B){return f[fa[A]] + mu2(s[B] - s[A] + ) * a[B];}
LL Cross(int A,int B,int C){return (x(C) - x(B)) * (y(A) - y(B)) - (x(A) - x(B)) * (y(C) - y(B));}
int finds(int x)
{
int l = st[a[x]] + ,r = st[a[x]] + t[a[x]] - ,ret = st[a[x]],mid;
while(l <= r)
{
mid = l + r >> ;
if(Get(que[mid],x) > Get(que[mid - ],x))ret = mid,l = mid + ;
else r = mid - ;
}
return ret;
}
int find(int x)
{
int l = st[a[x]] + ,r = st[a[x]] + t[a[x]] - ,ret = st[a[x]] + t[a[x]],mid;
while(l <= r)
{
mid = l + r >> ;
if(Cross(que[mid - ],que[mid],x) > )ret = mid,r = mid - ;
else l = mid + ;
}
return ret;
}
void dfs(int u)
{
pos[u] = t[a[u]];s[u] = ++cnt[a[u]];
qpos[u] = find(u);qtop[u] = que[qpos[u]];que[qpos[u]] = u;
t[a[u]] = qpos[u] - st[a[u]] + ;f[u] = Get(que[finds(u)],u);
for(int i = head[u];i;i = edge[i].nex)dfs(edge[i].to);
que[qpos[u]] = qtop[u];--cnt[a[u]];t[a[u]] = pos[u];
}
int main(){
scanf("%d",&n);
for(int i = ;i <= n;i++)scanf("%d",&a[i]),b[i] = a[i];
sort(b + ,b + n + );scanf("%d",&fa[]);
for(int i = ;i <= n;i++)if(b[i] != b[i - ])st[b[i]] = i;
for(int i = ;i <= n;i++)scanf("%d",&fa[i]),AddEdge(fa[i],i);
dfs();
for(int i = ;i <= n;i++)printf("%lld ",f[i]);
}
[洛谷U22158]策划体验(树上斜率优化)(二分最优决策)的更多相关文章
- 洛谷P2365 任务安排(斜率优化dp)
传送门 思路: 最朴素的dp式子很好考虑:设\(dp(i,j)\)表示前\(i\)个任务,共\(j\)批的最小代价. 那么转移方程就有: \[ dp(i,j)=min\{dp(k,j-1)+(sumT ...
- 洛谷P2120 [ZJOI2007]仓库建设 斜率优化DP
做的第一道斜率优化\(DP\)QwQ 原题链接1/原题链接2 首先考虑\(O(n^2)\)的做法:设\(f[i]\)表示在\(i\)处建仓库的最小费用,则有转移方程: \(f[i]=min\{f[j] ...
- 洛谷P4027 [NOI2007]货币兑换(dp 斜率优化 cdq 二分)
题意 题目链接 Sol 解题的关键是看到题目里的提示... 设\(f[i]\)表示到第\(i\)天所持有软妹币的最大数量,显然答案为\(max_{i = 1}^n f[i]\) 转移为\(f_i = ...
- 洛谷P4072 [SDOI2016]征途(斜率优化)
传送门 推式子(快哭了……)$$s^2*m^2=\sum _{i=1}^m (x_i-\bar{x})^2$$ $$s^2*m^2=m*\sum _{i=1}^m x_i^2-2*sum_n\sum ...
- 【洛谷 P5017】 摆渡车(斜率优化)
题目链接 算是巩固了一下斜率优化吧. 设\(f[i]\)表示前\(i\)分钟最少等待时间. 则有\(f[i]=\min_{j=0}^{i-m}f[j]+(cnt[i]-cnt[j])*i-(sum[i ...
- 洛谷3571 POI2014 SUP-Supercomputer (斜率优化)
一道神仙好题. 首先看到有多组\(k\),第一反应就是离线. 考虑贪心. 我们每次一定是尽量选择有儿子的节点.以便于我们下一次扩展. 但是对于一个\(k\),每次贪心的复杂度是\(O(n)\) 总复杂 ...
- 洛谷4072 SDOI2016征途 (斜率优化+dp)
首先根据题目中给的要求,推一下方差的柿子. \[v\times m^2 = m\times \sum x^2 - 2 \times sum \times sum +sum*sum \] 所以\(ans ...
- [NOI2014]购票 「树上斜率优化」
首先易得方程,且经过变换有 $$\begin{aligned} f_i &= \min\limits_{dist_i - lim_i \le dist_j} \{f_j + (dist_i - ...
- BZOJ_2726_[SDOI2012]任务安排_斜率优化+二分
BZOJ_2726_[SDOI2012]任务安排_斜率优化+二分 Description 机器上有N个需要处理的任务,它们构成了一个序列.这些任务被标号为1到N,因此序列的排列为1,2,3...N.这 ...
随机推荐
- ubuntu下php安装目录说明
php当前安装目录 /etc/php5/ apache2: 采用APACHE2HANDLER启动 cli: 采用命令启动 fpm php-fpm启动 fpm2 php-fpm多实例 m ...
- Android(java)学习笔记177: 服务(service)之音乐播放器
1.我们播放音乐,希望在后台长期运行,不希望因为内存不足等等原因,从而导致被gc回收,音乐播放终止,所以我们这里使用服务Service创建一个音乐播放器. 2.创建一个音乐播放器项目(使用服务) (1 ...
- Android(java)学习笔记174:服务(service)之混合方式开启服务
1. 前面我们已经讲过可以使用两种方式开启服务 startService----stopService: oncreate() ---> onstartCommand() ---& ...
- 写的一个HttpClient类
package com.ca.test.cainterface.common.util.http; import com.ca.test.cainterface.common.util.data.Da ...
- vue iview render里面 没有双向绑定 renderHeader 要序列化 反序列 一下
vue iview render里面 没有双向绑定 renderHeader 要序列化 反序列 一下 renderHeader: (h, params) => { return [ h('Rad ...
- struct获取不到值的小错误
struct2 get set 这两个方法一定要用双骆驼命名法:getA() setA(), 而geta() seta()不行 我找了好久的错误,只能说框架这东西快捷方便,找起错误要人命
- Windows 命令收集
定时关机命令:schtasks /create /tn "关机" /tr "shutdown /s" /sc once /st 23:55
- openjdk-alpine镜像无法打印线程堆栈和内存堆栈问题
基于openjdk:8u171-alpine构建的java镜像,使用jstack命令打印线程的时候会提示以下错误: /opt # ps -ef PID USER TIME COMMAND 1 root ...
- Java实现深拷贝和浅拷贝
1.类实现Cloneable才可以进行对象拷贝 2.Cloneable只实现浅拷贝,需要实现深拷贝的必须要重写clone()方法 3.利用反序列化也可以实现深拷贝,但是反序列化耗时较长 n.浅拷贝是指 ...
- JAVA:windows myeclipse jdk tomcat maven 完美搭建
文章来源:http://www.cnblogs.com/hello-tl/p/8305027.html 0.下载所需安装包 jdk-7u71-windows-x64.exe 链接:http://p ...