P4425 【[HNOI/AHOI2018]转盘】
颂魔眼中的一眼题我大湖南竟无一人\(AC\)
首先我们考虑一个性质:我们肯定存在一种最优解,满足从某个点出发,一直往前走,不停下来。
证明:我们假设存在一种最优解,是在\(t_i\)的时候到达\(a\)点,那么我肯定会在\(t_i - x(x≥1)\)的时间会到达\(a - 1\)号点
我们假设\(x != 1\),即我们会在\(a-1\)点进行停留,此时那么我们到达\(a - 2\)号点的时间\(<t_i - 2\),到达\(a-3\)号点的时间\(<t_i - 3\)
那么如果我有一个点\(a - y\)是在\(t_i - y\)时刻出现,那么我们不能取到这个点,必须要重新转一圈
那么如果\(x = 1\),且每一次走都没停下来,我们可以保证我们在\(x!=1\)经过该点后经过该点
所以说如果\(x!=1\)可以经过的所有点我们肯定在\(x==1\)的情况下都能经过,而且\(x==1\)情况下的一些点,\(x != 1\)不一定能经过,所以我们肯定每一次取\(x==1\)是一种最优情况
然后我们考虑进一步转化题意:假设我在一个点,从\(T_i\)时刻出发,满足转一圈刚好标记所有点,那么我们\(T_i\)以前的时间实际上是没有用的
由于环不好处理,而且转化后我们保证只要走一圈,所以我们可以断环成链
于是我们可以考虑,找到一个最好的起点\(i\),找到最好的\(T_i\),使得从i点在\(T_i\)时刻出发答案最优,即我们要求这个式子:\(min(T_i+n)\)其中满足对于任意的\(x\),\(T_i≥t_x-x+i\)
即我们要求:\(min_{i=1}^n(n + max_{x=i+1}^{2*n}(i-x + t_x))=min_{i=1}^n(n+i+max_{x=i+1}^{2*n}(x-t_x))\)
所以我们枚举每一个起点,找到最大的\(t_x-x\),用线段树维护,单次操作复杂度为\(O(NlogN)\),现在问题要考虑怎么修改
令\(a_i=t_i-i\),所以原式变成\(n+min_{i=1}^n(max_{x=i+1}^{2*n}(a_x)+i)\)
不难发现,\(max_{x=i+1}^{i+n}(a_x)\)是单调不增的。于是,我们维护一个单调栈,对于每一个\(max_{x=i+1}^{i+n}(a_x)\)连续的一段,找到一个最小的\(i\)即可,单调栈可以用线段树来维护(详见我楼房重建的题解),把楼房重建的求和改成\(max\)就行了,于是复杂度就变成了\(O(Nlog^2N)\)
\(Code:\)
#include<bits/stdc++.h>
using namespace std;
int read() {
int x = 0, f = 1; char c = getchar();
while(c < '0' || c > '9') { if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - 48, c = getchar();
return x * f;
}
#define rep(i, s, t) for(int i = s; i <= t; ++ i)
#define ls k * 2
#define rs k * 2 + 1
#define maxn 100005
int n, m, p, last, a[maxn << 1], ma[maxn << 3], ans[maxn << 3];
int query(int k, int l, int r, int v) {
if(l == r) return l + max(v, ma[k]);
int mid = (l + r) >> 1;
if(ma[rs] >= v) return min(ans[k], query(rs, mid + 1, r, v));
return min(mid + v + 1, query(ls, l, mid, v));
}
inline void updata(int k, int l, int r, int mid) {
ma[k] = max(ma[ls], ma[rs]), ans[k] = query(ls, l, mid, ma[rs]);
}
void modify(int k, int l, int r, int ll) {
if(l == r) return (void)(ans[k] = a[l] + l, ma[k] = a[l]);
int mid = (l + r) >> 1;
if(ll <= mid) modify(ls, l, mid, ll);
else modify(rs, mid + 1, r, ll);
updata(k, l, r, mid);
}
void build(int k, int l, int r) {
if(l == r) return (void)(ans[k] = a[l] + l, ma[k] = a[l]);
int mid = (l + r) >> 1;
build(ls, l, mid), build(rs, mid + 1, r), updata(k, l, r, mid);
}
int main() {
n = read(), m = read(), p = read();
rep(i, 1, n) a[i] = read() - i, a[i + n] = a[i] - n;
build(1, 1, n * 2);
printf("%d\n", last = ans[1] + n - 1);
rep(i, 1, m) {
int x = read() ^ (p * last), y = read() ^ (p * last);
a[x] = y - x, a[x + n] = y - x - n, modify(1, 1, 2 * n, x), modify(1, 1, 2 * n, x + n);
printf("%d\n", last = ans[1] + n - 1);
}
return 0;
}
P4425 【[HNOI/AHOI2018]转盘】的更多相关文章
- 洛谷P4425 [HNOI/AHOI2018]转盘(线段树)
题意 题目链接 Sol 首先猜一个结论:对于每次询问,枚举一个起点然后不断等到某个点出现时才走到下一个点一定是最优的. 证明不会,考场上拍了3w组没错应该就是对的吧... 首先把数组倍长一下方便枚举起 ...
- [HNOI/AHOI2018]转盘(线段树优化单调)
gugu bz lei了lei了,事独流体毒瘤题 一句话题意:任选一个点开始,每个时刻向前走一步或者站着不动 问实现每一个点都在$T_i$之后被访问到的最短时间 Step 1 该题可证: 最优方案必 ...
- BZOJ5286:[HNOI/AHOI2018]转盘——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=5286 https://www.luogu.org/problemnew/show/P4425 ht ...
- [HNOI/AHOI2018]转盘
一个结论:一定存在一个最优解只走一圈.否则考虑从最后一个结束位置开始一定可以达到相同效果 画个图,类似是一种斜线感觉 考虑一个高度贡献的最高点 对于i开始的连续n个,答案是:max(Tj-j)+i+n ...
- BZOJ5286 HNOI/AHOI2018转盘(分块/线段树)
显然最优走法是先一直停在初始位置然后一次性走完一圈.将序列倍长后,相当于找一个长度为n的区间[l,l+n),使其中ti+l+n-1-i的最大值最小.容易发现ti-i>ti+n-(i+n),所以也 ...
- 【题解】Luogu P4436 [HNOI/AHOI2018]游戏
原题传送门 \(n^2\)过百万在HNOI/AHOI2018中真的成功了qwqwq 先将没门分格的地方连起来,枚举每一个块,看向左向右最多能走多远,最坏复杂度\(O(n^2)\),但出题人竟然没卡(建 ...
- [Bzoj5285][洛谷P4424][HNOI/AHOI2018]寻宝游戏(bitset)
P4424 [HNOI/AHOI2018]寻宝游戏 某大学每年都会有一次Mystery Hunt的活动,玩家需要根据设置的线索解谜,找到宝藏的位置,前一年获胜的队伍可以获得这一年出题的机会. 作为新生 ...
- 【LG4437】[HNOI/AHOI2018]排列
[LG4437][HNOI/AHOI2018]排列 题面 洛谷 题解 题面里这个毒瘤的东西我们转化一下: 对于\(\forall k,j\),若\(p_k=a_{p_j}\),则\(k<j\). ...
- 洛谷P4425 转盘 [HNOI/AHOI2018] 线段树+单调栈
正解:线段树+单调栈 解题报告: 传送门! 1551又是一道灵巧连题意都麻油看懂的题,,,,所以先解释一下题意好了,,,, 给定一个n元环 可以从0时刻开始从任一位置出发 每次可以选择向前走一步或者在 ...
随机推荐
- SQL Server 索引优化——无用索引
我们知道,合理的索引能大幅提升性能,但冗余的索引也会降低数据库性能.随着我们业务的发展,数据库的中的表.表结构.查询的内容都有可能发生变化.这样,有的索引就可能不再使用了,需要删除(因为维护索引即浪费 ...
- 从学习“单例模式”学到的Java知识:双重检查锁和延迟初始化
一切真是有缘,上午刚刚看完单例模式,还在为其中的代码块同步而兴奋,下午就遇见这篇文章:双重检查锁定与延迟初始化.我一看,文章开头语出惊人,说这是一种错误的优化,我说,难道上午学的东西下午就过时了吗?仔 ...
- sqlserver 汉字转拼音(转载)
转载来源一:https://www.cnblogs.com/zhuisuo/archive/2012/01/11/2318908.html 汉字转全拼音函数优化方案(SQLServer),值得你看看 ...
- Android笔记(六十八) Fragment总结
Fragment的产生: 为了适应各种尺寸的屏幕,谷歌推出Fragment,可以把Fragment成Activity的一个组成部分,它拥有自己的生命周期.可以接收并处理用户的各种事件,还可以动态的增删 ...
- 【转】高性能网络编程1----accept建立连接
最近在部门内做了个高性能网络编程的培训,近日整理了下PPT,欲写成一系列文章从应用角度谈谈它. 编写服务器时,许多程序员习惯于使用高层次的组件.中间件(例如OO(面向对象)层层封装过的开源组件),相比 ...
- LB_Yi
LB_Yi 简述 LB_Yi也是一种比较常见的下界函数,在时间序列的筛选中十分常见.是由Yi在Kim的基础上设计的下界函数. 公式 LB_Yi的公式如下: 从公式中可以明显的看出,其实就是把大于序列最 ...
- 2013.5.23 - KDD第三十五天
看完睡不觉得世间有点虚度,然后就构思了一下带带回儿去找中秋要跟她说的事情,大概就是这样的: 我 打算用paper来计算人与人之间的距离,比如说我跟郑茂和写过一篇文章,然后郑茂根韩冰和写过一篇文章, ...
- 从零开始配置MacBook Pro
购买macbook, 是因为它的效率性.由于我第一次使用macbook,所以按照我开发的习惯和参照了其他人的文章进行配置我的个人mac,希望我的设置对你们也有所帮助 1.基本配置 查找我的Mac 系统 ...
- docker 运行ELK
docker network create somenetwork docker run -d --name elasticsearch --net somenetwork -p 9200:9200 ...
- 剑指Offer(二十四):二叉树中和为某一值的路径
剑指Offer(二十四):二叉树中和为某一值的路径 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.ne ...