【PKUSC2018】星际穿越
被 scb 神仙教育来扫荡北大营题目 Orz
Description
Solution
首先有个很显然的性质,就是对于一组询问 \(l,r,x\),从 \(x\) 到 \([l,r]\) 的最短距离 一定是从 \(x\) 一直向左走 或者从 \(x\) 向右走 \(1\) 单位时间然后一直向左走。
向右走 \(1\) 单位时间到达的位置是 \(L_i\) 最小的 \(i\)。如果 \(\min\{L_i\}\ge L_x\) 那就不用考虑向右走一步的情况了,否则在 \(\min\{L_i\}\lt L_x\lt x\) 的限制下,我们可以从 \(x\) 一步到 \(i\)。
然后 \(70\) 分做法就很显然了,从每个点出发,模拟上面两个情况即可。
code (我之前把 \(q\) 也看成 \(5000\) 了,所以 T 了好几发)
以上过程看起来可以倍增优化,然后就开始学习倍增转移技巧
首先不分开考虑向右走和不向右走两种情况,我们在查询时先强制从 \(x\) 向左走一次,然后再往前倍增走即可,画图可知这样两种情况就合一了。此时我们不用考虑向右走的情况了,但强制往左走一次后再往左走到的位置 就要取位置 \([x,n]\) 中所有 \(L_i\) 的最小值,因为可能是从 \((x,n]\) 中某个位置走来的,即之前从 \(x\) 往右走了一步(如果 \(L_x\) 最小就无视这一步)。
然后根据一开始说过的性质,最优答案最多只在一开始位于 \((x,n]\) 之间的位置,以后不会闲的蛋疼再回到那些位置,故一直顺带记录那些位置能到达的最左位置 不会影响找到最优解。
这样代码就好实现了:预处理 \(to(i,j)\) 表示从 \([i,n]\) 中任一位置向左走 \(j\) 个单位时间,最左可以走到哪个位置;再预处理 \(sum(i,j)\) 表示从 \(i\) 到 \([to(i,j),i)\) 区间内所有位置的最短距离之和。
查询时倍增跑到询问区间 \([l,r]\) 的左端点 \(l\) 即可。
详见代码。
#include<bits/stdc++.h>
#define ll long long
#define N 300001
using namespace std;
inline int read(){
int x=0; bool f=1; char c=getchar();
for(;!isdigit(c); c=getchar()) if(c=='-') f=0;
for(; isdigit(c); c=getchar()) x=(x<<3)+(x<<1)+(c^'0');
if(f) return x;
return 0-x;
}
int n,q,L[N],to[20][N]; ll sum[20][N];
ll gcd(ll x, ll y){
ll t;
while(y) t=x, x=y, y=t%y;
return x;
}
ll calc(int l, int r){
if(L[r]<=l) return r-l;
ll ans=r-L[r]; r=L[r]; int tot=1;
for(int i=19; ~i; --i) if(to[i][r]>l) ans+=sum[i][r]+(ll)tot*(r-to[i][r]), r=to[i][r], tot+=1<<i;
return ans+(ll)(r-l)*(tot+1);
}
int main(){
n=read(); L[1]=1;
for(int i=2; i<=n; ++i) L[i]=read();
to[0][n]=L[n], sum[0][n]=n-L[n];
for(int i=n-1; i; --i) to[0][i]=min(to[0][i+1],L[i]), sum[0][i]=i-to[0][i];
for(int i=1; i<=19; ++i)
for(int j=1; j<=n; ++j)
to[i][j] = to[i-1][to[i-1][j]],
sum[i][j] = sum[i-1][j] + sum[i-1][to[i-1][j]] + (ll)(to[i-1][j]-to[i][j])*(1<<(i-1));
q=read(); int l,r,x;
while(q--){
l=read(), r=read(), x=read();
ll a=calc(l,x)-calc(r+1,x), b=r-l+1, g=gcd(a,b);
printf("%lld/%lld\n",a/g,b/g);
}
return 0;
}
【PKUSC2018】星际穿越的更多相关文章
- [PKUSC2018]星际穿越
[PKUSC2018]星际穿越 题目大意: 有一排编号为\(1\sim n\)的\(n(n\le3\times10^5)\)个点,第\(i(i\ge 2)\)个点与\([l_i,i-1]\)之间所有点 ...
- [Luogu 5465] [LOJ 6435] [PKUSC2018]星际穿越(倍增)
[Luogu 5465] [LOJ 6435] [PKUSC2018]星际穿越(倍增) 题面 n个点的图,点i和[l[i],i)的所有点连双向边.每次询问(l,r,x)表示x到[l,r]的所有点的最短 ...
- BZOJ5371[Pkusc2018]星际穿越——可持久化线段树+DP
题目描述 有n个星球,它们的编号是1到n,它们坐落在同一个星系内,这个星系可以抽象为一条数轴,每个星球都是数轴上的一个点, 特别地,编号为i的星球的坐标是i. 一开始,由于科技上的原因,这n个星球的居 ...
- LOJ.6435.[PKUSC2018]星际穿越(倍增)
LOJ BZOJ 参考这儿qwq. 首先询问都是求,向左走的最短路. \(f[i][j]\)表示从\(i\)走到\(j\)最少需要多少步.表示这样只会\(O(n^2\log n)\)的= =但是感觉能 ...
- [PKUSC2018]星际穿越(倍增)
题意:n个点的图,点i和[l[i],i)的所有点连双向边.每次询问(l,r,x)表示x到[l,r]的所有点的最短路径长度和. 首先这题显然可以线段树优化建图,但是需要比较好的常数才能通过45分,还需要 ...
- 2019.03.09 bzoj5371: [Pkusc2018]星际穿越(主席树)
传送门 题意简述: 给一个序列,对于第iii个位置,它跟[limi,i−1][lim_i,i-1][limi,i−1]这些位置都存在一条长度为111的无向边. 称dist(u,v)dist(u,v) ...
- 【洛谷5465】[PKUSC2018] 星际穿越(倍增)
点此看题面 大致题意: 给定\(l_{2\sim n}\),其中\(l_i\)表示\([l_i,i-1]\)的所有点与\(i\)之间存在一条长度为\(1\)的双向路径.每次询问给出\(l,r,x\), ...
- LOJ6435 PKUSC2018 星际穿越
这个题吧当时在考场只得了45分 然后70分的性质都分析到了 不知道为啥就是写萎蛋了 哎 当时还是too young too simple 看了一下julao们的博客这个题有两种做法 一个是比较费脑子的 ...
- 题解 洛谷 P5465 【[PKUSC2018]星际穿越】
首先考虑题目的性质,发现点向区间连的边为双向边,所以也就可以从一个点向右跳到区间包含该点的点,如图所示: 但事实上向后跳其实是不优的,可以有更好的方法来节省花费: 因此我们发现一个点跳到其前一个区间的 ...
- 「PKUSC2018」星际穿越 (70分做法)
5371: [Pkusc2018]星际穿越 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 27 Solved: 11[Submit][Status] ...
随机推荐
- ForeFront TMG标准版
ForeFront TMG 标准版安装指南 目前 Forefonrt TMG 的RTM版本已经正式发布,你可以在 ISA中文站上下载120天测试版本: http://www.isacn.org/inf ...
- C#规范整理·资源管理和序列化
资源管理(尤其是内存回收)曾经是程序员的噩梦,不过在.NET平台上这个噩梦似乎已经不复存在.CLR在后台为垃圾回收做了很多事情,使得我们现在谈起在.NET上进行开发时,都会说还是new一个对象吧!回收 ...
- 【Python】【demo实验21】【练习实例】【求球反弹高度】
原题: 一球从100米高度自由落下,每次落地后反跳回原高度的一半:再落下,求它在第10次落地时,共经过多少米?第10次反弹多高? 我的源码: #!/usr/bin/python # encoding= ...
- 基于.NET架构的树形动态报表设计与应用
在一些统计报表中,利用树形结构报表来实现维度钻取功能是十分常见的.通过逐级钻取,可以快速查看更细粒度的指标数据,如项目施工进度报告等. 使用葡萄城报表控件——ActiveReports ,即可轻松设计 ...
- PAT A1012 Best Rank(25)
题目描述 To evaluate the performance of our first year CS majored students, we consider their grades of ...
- P1541 乌龟棋(动态规划)
(点击此处查看原题) 题意 此处有n个位置,记为1~n,每个位置上都对应一个权值,乌龟从编号为1的位置出发,利用m张爬行卡片到达位置n,爬行卡牌有四种,分别可以让乌龟移动1,2,3,4步,并保证将m张 ...
- # codeblocks 使用技巧+伪单文件编译
codeblocks 使用技巧+伪单文件编译 shift+F2打开和隐藏左侧工作空间 F2 打开和隐藏下面控制台 CTRL+Shift+c 注释,CTRL+Shift+x取消注释 view->p ...
- logid让你的请求完整可追溯
今天是在博客园开园的第一天 一时间其实并不能想起来到底该写什么文章,其实想写的东西挺多 今天就以logid这个主题开始吧,网上写这个的文章似乎不多,但是的确是在实际生产中相当重要的一个能力,也是容易被 ...
- python — 进程
目录 1. 进程 1.进程就是一个运行中的程序(是对正在运行程序的一个抽象). 2.程序和进程之间的区别: 程序只是一个文件 进程是这个文件被CPU运行起来了 程序是永久的,进程是暂时的. 3.进程- ...
- 深入理解Redux之手写React-Redux
React-Redux主要由两部分组成,一是Provider(提供者),顾名思义作用就是提供状态数据. 另一部分是connect函数,它的作用是把UI组件和状态数据“连接”起来,实现了Model和Vi ...