[HNOI/AHOI2018]转盘(线段树优化单调)
[HNOI/AHOI2018]转盘(线段树优化单调)
lei了lei了,事独流体毒瘤题
一句话题意:任选一个点开始,每个时刻向前走一步或者站着不动
问实现每一个点都在$T_i$之后被访问到的最短时间
Step 1
该题可证:
最优方案必然是从某一格开始后一直等着然后走一圈正好全部访问到
证明:
如果时间倒流那就是从时刻T开始每一时刻向前走或是停着不动,每个元素过了T[i]会消失
如果这样的话你肯定是马不停蹄往前走对吧
所以反过来就是上面的结论
Q.E.D
上面的结论还有其他正确的表示方法,该方法仅供参考
如果您能想出其他证明,那么请让我Orz您
Step 2
根据上述结论,答案出来了$min_{i=1}^{n}(\max_{j=i}^{i+n-1}(T_j-j+i))+n-1$
暴力胡写都有$n^2$20分,可惜我考场上直接放弃
介个是用线段树优化的说...
简单思路:$T_j-j$可以单独提出来设为$f_j$
原式可变成$\min_{i=1}^{n}(\max_{j=i}^{i+n-1}(f_j)+i)+n-1$
做这道题之前我也没见过log的pushup
随手找了点参考文献(???)[luoguP4198]楼房重建
事实上并没有什么关系,但是确实十分相似
线段树维护方法都是差不多的,随便yy应该就差不多
代码:
#include<cstdio>
#include<algorithm>
using std::max;
using std::min;
const int N=;
int n,T,plas;
int v[N],f[N];
struct segtree
{
int ma[N<<],ans[N<<];
int query(int vi,int px,int pl,int pr)
{
if(pl==pr) return pl+max(ma[px],vi);
int mid=(pl+pr)>>;
if(ma[px<<|]>vi) return min(ans[px],query(vi,px<<|,mid+,pr));
else return min(mid++vi,query(vi,px<<,pl,mid));
}
void fuckup(int px,int pl,int pr)
{
ma[px]=max(ma[px<<],ma[px<<|]);
ans[px]=query(ma[px<<|],px<<,pl,(pl+pr)>>);
}
void add(int x,int px,int pl,int pr)
{
if(pl==pr)
{
ma[px]=f[x],ans[px]=v[x];
return;
}
int mid=(pl+pr)>>;
if(x<=mid) add(x,px<<,pl,mid);
else add(x,px<<|,mid+,pr);
fuckup(px,pl,pr);
}
int get()
{
return ans[]+n-;
}
}rk;
int xin,vin; int lastans;
int main()
{
scanf("%d%d%d",&n,&T,&plas);
for(int i=;i<=n;i++) scanf("%d",&v[i]),v[i+n]=v[i],f[i]=v[i]-i,f[i+n]=v[i+n]-i-n;
for(int i=;i<=n<<;i++) rk.add(i,,,n<<);
lastans=rk.get();
printf("%d\n",lastans);
if(!plas) lastans=;
while(T--)
{
scanf("%d%d",&xin,&vin);
xin^=lastans,vin^=lastans;
v[xin]=vin,v[xin+n]=vin,f[xin]=v[xin]-xin,f[xin+n]=v[xin+n]-xin-n;
rk.add(xin,,,n<<),rk.add(xin+n,,,n<<);
lastans=rk.get();
printf("%d\n",lastans);
if(!plas) lastans=;
}
return ;
}
巨佬您txdy
[HNOI/AHOI2018]转盘(线段树优化单调)的更多相关文章
- 洛谷P4425 [HNOI/AHOI2018]转盘(线段树)
题意 题目链接 Sol 首先猜一个结论:对于每次询问,枚举一个起点然后不断等到某个点出现时才走到下一个点一定是最优的. 证明不会,考场上拍了3w组没错应该就是对的吧... 首先把数组倍长一下方便枚举起 ...
- 完美字符子串 单调队列预处理+DP线段树优化
题意:有一个长度为n的字符串,每一位只会是p或j.你需要取出一个子串S(注意不是子序列),使得该子串不管是从左往右还是从右往左取,都保证每时每刻已取出的p的个数不小于j的个数.如果你的子串是最长的,那 ...
- bzoj 1171 并查集优化顺序枚举 | 线段树套单调队列
详见vfleaking在discuss里的题解. 收获: 当我们要顺序枚举一个序列,并且跳过某些元素,那么我们可以用并查集将要跳过的元素合并到一起,这样当一长串元素需要跳过时,可以O(1)跳过. 暴力 ...
- [USACO2005][POJ3171]Cleaning Shifts(DP+线段树优化)
题目:http://poj.org/problem?id=3171 题意:给你n个区间[a,b],每个区间都有一个费用c,要你用最小的费用覆盖区间[M,E] 分析:经典的区间覆盖问题,百度可以搜到这个 ...
- [NOI2016]区间 题解(决策单调性+线段树优化)
4653: [Noi2016]区间 Time Limit: 60 Sec Memory Limit: 256 MBSubmit: 1593 Solved: 869[Submit][Status][ ...
- HDU多校第三场 Hdu6606 Distribution of books 线段树优化DP
Hdu6606 Distribution of books 题意 把一段连续的数字分成k段,不能有空段且段和段之间不能有间隔,但是可以舍去一部分后缀数字,求\(min(max((\sum ai ))\ ...
- 4.11 省选模拟赛 序列 二分 线段树优化dp set优化dp 缩点
容易想到二分. 看到第一个条件容易想到缩点. 第二个条件自然是分段 然后让总和最小 容易想到dp. 缩点为先:我是采用了取了一个前缀最小值数组 二分+并查集缩点 当然也是可以直接采用 其他的奇奇怪怪的 ...
- Codeforces 1603D - Artistic Partition(莫反+线段树优化 dp)
Codeforces 题面传送门 & 洛谷题面传送门 学 whk 时比较无聊开了道题做做发现是道神题( 介绍一种不太一样的做法,不观察出决策单调性也可以做. 首先一个很 trivial 的 o ...
- Weak Pair---hud5877大连网选(线段树优化+dfs)
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5877 题意:给你一颗树,有n个节点,每个节点都有一个权值v[i]:现在求有多少对(u,v ...
随机推荐
- 07_传智播客iOS视频教程_#import指令
mac切换中英文输入法默认是Ctrl+空格键. 预处理指令的执行时机是在编译之前.在编译之前执行预处理指令. #import指令是包含文件,将指定的文件的内容在预编译的时候拷贝到写指令的地方. #im ...
- java-通过反射获取目标类的属性,方法,构造器
首先定义一个urse package com.studay_fanshe; public class User { private String uname; private int age; pri ...
- Luogu P3320 [SDOI2015]寻宝游戏 / 异象石 【LCA/set】
期末考试结束祭! 在期末考试前最后一发的测试中,异象石作为第二道题目出现QAQ.虽然知道是LCA图论,但还是敲不出来QAQ. 花了两天竞赛课的时间搞懂(逃 异象石(stone.pas/c/cpp)题目 ...
- setsockopt()函数功能介绍
功能描述: 获取或者设置与某个套接字关联的选 项.选项可能存在于多层协议中,它们总会出现在最上面的套接字层.当操作套接字选项时, 选项位于的层和选项的名称必须给出.为了操作套接字层的选项,应该 将层的 ...
- _bzoj1026 [SCOI2009]windy数【数位dp】
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1026 数位dp果断记忆化搜索,代码量少~ 程序里我用11代表前导零. #include &l ...
- 校赛F 比比谁更快(线段树)
http://acm.cug.edu.cn/JudgeOnline/problem.php?cid=1153&pid=5 题意:给你一个字符串,各两个操作: ch=0,[l,r]降序 ch=1 ...
- DP Codeforces Round #260 (Div. 1) A. Boredom
题目传送门 /* 题意:选择a[k]然后a[k]-1和a[k]+1的全部删除,得到点数a[k],问最大点数 DP:状态转移方程:dp[i] = max (dp[i-1], dp[i-2] + (ll) ...
- F 点与多边形 数学 + 观察
https://biancheng.love/contest-ng/index.html#/123/problems 做题要在纸上弄弄,才会有发现. 发现到答案只是-1和4,因为坐标都是整数. 然后就 ...
- Linux终端下对话
1.首先查看当前账户 [hadoop@weekend01 ~]$ who hadoop tty1 2016-11-14 09:31 (:0) hadoop pts/0 ...
- andorid IOS 判断APP下载
<?phpif(strpos($_SERVER['HTTP_USER_AGENT'], 'iPhone')||strpos($_SERVER['HTTP_USER_AGENT'], 'iPad' ...