【题解】 bzoj3956: Count (ST表+单调栈)
Solution
- 看了一点点题解,自己又刚了\(2h30min\),刚了出来qwq,我好菜啊qwq
- 貌似这道题是BZOJ 4826的弱化,弱化都不会qwq凉凉
- Solution
- 首先你可以考虑,找出\([l,r]\)的最大值(\(x\))后,你会发现这个好的点对,是不会跨过这最大值(\(x\))的,那么答案就是\([l,x]\)的所有点作为点对左端的方案数\(+\) \([x+1,r]\)所有点作为点对右端的方案数
- 求方案数我们就可以用单调栈\(O(n)\)求出来,然后做一次前缀和就好了
- 这个单调栈操作我觉得这个贼鸡儿难,调了很多特殊数据终于过了
- 具体操作:
相邻的两个值(a,b)不论怎样肯定是一个点对,如果单调栈处理,因为我们要处理出作为左端点的方案数和右端段的方案数,相邻的这种点对就会在\(a\)为左端点时加一次,在\(b\)为右端点的时候加一次,这样会有重复,比较麻烦,我们就不考虑这种相邻的情况(这样最后的答案就是\([l,x-1]\)的所有点作为点对左端的方案数加 \([x+1,r]\)所有点作为点对右端的方案数,因为\(x\)最大只会是与相邻两个成点对)
现在假定我们求每个点为点对左端点的方案数
后面的操作就是:我们维护一个单调上升的栈,每入队一个点,如果这个点比队尾大,队尾的这个点如果不是现在加入的点的相邻点,我们就把他的方案数\(+1\),然后弹出(因为你想,如果这个点不相邻,中间的全部被弹出,说明一定不会大于这两边的两个)
稍微特殊的情况就是,如果队尾的值(假设为\(a_1\))与现在加入的值(假设为\(a_2\))相等,那么我们就给队尾的方案数\(+1\),然后弹出,并且把这个新加入的点作为队尾。(\(*\)解释在后面)
(\(*\))解释:因为题目要求是大于,所以中间存在与两边等于的情况也是不行的,所以\(a_2\)不会对\(a_1\)之前的点有贡献,\(a_1\)不会对\(a_2\)之后的点有贡献。
然后弹完队尾后,我们把这个现在的队尾的方案数加一,原因同上,他们两之间的数一定小于两边,然后把点入队即可
最后没弹出队列的点不用管,因为他们单调递增,比如\(a,b,c\)(\(a<b<c\)),后面不会再有点与\(a\)形成点对,因为\(b,c\)一定大于\(a\)
右端点的反着来一边就好了
最后计算答案记得加上相邻的方案数即可
那个查询最大值可以用\(ST表\),也可以用线段树,(本来是要练习\(ST\)表的,结果调单调栈调了好久qwq
感觉这道题还是挺神的吧,把思路理了一边总算清楚很多了.
Code
- 调了好久,写的丑
//It is coded by ning_mew on 7.19
#include<bits/stdc++.h>
#define LL long long
using namespace std;
const int maxn=3e5+7,inf=1e9+7;
int n,m,Type;
LL sl[maxn],sr[maxn],two[25],lastans=0;
int team[maxn],s[maxn],tl=1,ST[maxn][25],Log[maxn];
int maxa(int x,int y){if(s[x]>s[y])return x;return y;}
int quary(int l,int r){
int k=Log[r-l+1];
return maxa(ST[l][k],ST[r-two[k]+1][k]);
}
void pre(){
two[0]=1;
for(int i=2;i<=n;i++)Log[i]=Log[i>>1]+1;
for(int i=1;i<=16;i++)two[i]=two[i-1]*2;
for(int j=1;j<=16;j++)
for(int i=1;i+two[j-1]<=n;i++){
ST[i][j]=maxa(ST[i][j-1],ST[i+two[j-1]][j-1]);
}
}
void work(int l,int r){
int k=quary(l,r);
lastans=sl[k-1]-sl[l-1]+sr[r]-sr[k]+r-l;
printf("%lld\n",lastans);
if(!Type)lastans=0;return;
}
int main(){
scanf("%d%d%d",&n,&m,&Type);
for(int i=1;i<=n;i++)scanf("%d",&s[i]),ST[i][0]=i;
pre();
for(int i=1;i<=n;i++){
while(tl>1){
if(s[ team[tl-1] ]<=s[i]){
if(team[tl-1]!=i-1)sl[team[tl-1]]++;
if(s[team[tl-1]]==s[i]){break;}
tl--;
}
else break;
}
if(s[team[tl-1]]==s[i]){team[tl-1]=i;continue;}
if(team[tl-1]!=i-1)sl[team[tl-1]]++;
team[tl]=i;tl++;
}
memset(team,0,sizeof(team));tl=1;
for(int i=n;i>=1;i--){
while(tl>1){
if(s[ team[tl-1] ]<=s[i]){
if(team[tl-1]!=i+1)sr[team[tl-1]]++;
if(s[team[tl-1]]==s[i]){break;}
tl--;
}
else break;
}
if(s[team[tl-1]]==s[i]){team[tl-1]=i;continue;}
if(team[tl-1]!=i+1)sr[team[tl-1]]++;
team[tl]=i;tl++;
}
sl[0]=sr[n+1]=0;
for(int i=1;i<=n;i++)sl[i]=sl[i]+sl[i-1],sr[i]=sr[i]+sr[i-1];
lastans=0;
for(int i=1;i<=m;i++){
LL l,r;scanf("%lld%lld",&l,&r);
l=(l+lastans-1)%n+1;r=(r+lastans-1)%n+1;if(l>r)swap(l,r);
work(l,r);
}return 0;
}
博主蒟蒻,随意转载。但必须附上原文链接:http://www.cnblogs.com/Ning-Mew/,否则你会场场比赛暴0!!!
【题解】 bzoj3956: Count (ST表+单调栈)的更多相关文章
- 【BZOJ-3956】Count ST表 + 单调栈
3956: Count Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 173 Solved: 99[Submit][Status][Discuss] ...
- [多校联考2019(Round 4 T2)][51nod 1288]汽油补给(ST表+单调栈)
[51nod 1288]汽油补给(ST表+单调栈) 题面 有(N+1)个城市,0是起点N是终点,开车从0 -> 1 - > 2...... -> N,车每走1个单位距离消耗1个单位的 ...
- BZOJ4540 [Hnoi2016]序列 【莫队 + ST表 + 单调栈】
题目 给定长度为n的序列:a1,a2,-,an,记为a[1:n].类似地,a[l:r](1≤l≤r≤N)是指序列:al,al+1,-,ar- 1,ar.若1≤l≤s≤t≤r≤n,则称a[s:t]是a[ ...
- 【BZOJ3611】[Heoi2014]大工程 欧拉序+ST表+单调栈
[BZOJ3611][Heoi2014]大工程 Description 国家有一个大工程,要给一个非常大的交通网络里建一些新的通道. 我们这个国家位置非常特殊,可以看成是一个单位边权的树,城市位于顶 ...
- BZOJ 4453: cys就是要拿英魂![后缀数组 ST表 单调栈类似物]
4453: cys就是要拿英魂! Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 90 Solved: 46[Submit][Status][Discu ...
- bzoj千题计划313:bzoj3879: SvT(后缀数组+st表+单调栈)
https://www.lydsy.com/JudgeOnline/problem.php?id=3879 把所有的后缀取出,按rank排序 求出相邻两个后缀的lcp 每个后缀对答案的贡献就是 与在它 ...
- bzoj千题计划314:bzoj3238: [Ahoi2013]差异(后缀数组+st表+单调栈)
https://www.lydsy.com/JudgeOnline/problem.php?id=3238 跟 bzoj3879 差不多 #include<cstdio> #include ...
- Codeforces Round #278 (Div. 1) B - Strip dp+st表+单调队列
B - Strip 思路:简单dp,用st表+单调队列维护一下. #include<bits/stdc++.h> #define LL long long #define fi first ...
- 【BZOJ3956】Count 主席树+单调栈
[BZOJ3956]Count Description Input Output Sample Input 3 2 0 2 1 2 1 1 1 3 Sample Output 0 3 HINT M,N ...
随机推荐
- 通过jQuery Ajax使用FormData对象上传文件 (转载)
XMLHttpRequest Level 2 添加了一个新的接口——FormData.与普通的 Ajax 相比,使用 FormData 的最大优点就是我们可以异步上传二进制文件.jQuery 2.0+ ...
- Intel Digital Innovation Industry Summit(2018.08.17)
时间:2018.08.17地点:北京金隅喜来登大酒店
- LiveCharts文档-3开始-7标签
原文:LiveCharts文档-3开始-7标签 LiveCharts文档-3开始-7标签 Label就是Chart中表示数值的字符串,通常被放置在轴的位置和提示当中. 下图中的这些字符串显示的都是标签 ...
- sklearn学习笔记之简单线性回归
简单线性回归 线性回归是数据挖掘中的基础算法之一,从某种意义上来说,在学习函数的时候已经开始接触线性回归了,只不过那时候并没有涉及到误差项.线性回归的思想其实就是解一组方程,得到回归函数,不过在出现误 ...
- 【C#实现漫画算法系列】-判断 2 的乘方
微信上关注了算法爱好者这个公众号,有一个漫画算法系列的文章生动形象,感觉特别好,给大家推荐一下(没收过广告费哦),原文链接:漫画算法系列.也看到了许多同学用不同的语言来实现算法,作为一枚C#资深爱好的 ...
- (理论篇)从基础文件IO说起虚拟内存,内存文件映射,零拷贝
为了快速构建项目,使用高性能框架是我的职责,但若不去深究底层的细节会让我失去对技术的热爱. 探究的过程是痛苦并激动的,痛苦在于完全理解甚至要十天半月甚至没有机会去应用,激动在于技术的相同性,新的框架不 ...
- Centos7 中文乱码
1. 安装中文库 yum groupinstall "fonts" 2. 检查是否有中文语言包 locale -a 3. 查看当前系统语言环境 locale 解析如下 LANG:当 ...
- Linux大棚命令记录
查看系统支持的shell: cat /etc/shells 查看当前系统用的shell: echo $SHELL 从bash切换到zsh: 先yum安装,然后 chsh -s /bin/zsh ,退 ...
- 个人博客作业_week14
M1/M2阶段总结 我在M1阶段负责后端代码的开发,以及协助PM,在M2阶段负责PM,在为期将近一学期的团队软件开发过程中,我深刻体会到了团队协作的重要性,以及合理分配任务的重要性,没有一个好的时间规 ...
- 《Linux内核设计与实现》第三章学习笔记
第三章 进程管理 姓名:王玮怡 学号:20135116 一.进程 1.进程的含义 进程是处于执行期的程序以及相关资源的总称,程序本身并不是进程,实际上就是正在执行的代码的实时结果.Linux内核通 ...