Description

题面

Solution

分块套分块,分别对时间和位置进行分块

差不多是一个定期保存信息的方法

对于询问我们不妨求出 \(>=x\) 的答案,然后用 \(m-(>=x)\) 的答案,避免了严格小于带来的麻烦

暴力做法是把数字从大到小加入,然后每一次做区间修改,主席树维护一下,但空间复杂度太大

我们同样这么做,想办法均摊时间和空间复杂度

我们设定一个 \(S\),每过 \(S\) 的时间就将主席树维护的东西暴力存下来

但是暴力存下来空间开不下,我们想办法对序列分块,分别保存每一个块内的最大值

每一个时刻的修改,我们就对块外暴力做,块内打标记,因为我们每过 \(S\) 的时间就要暴力存,留到这个时候再放标记,大致就是这样

inline void Modify(int k,int l,int r){
if(b[l]==b[r]){
for(int i=l;i<=r;i++)w[i]++;
return ;
}
for(int i=l;i<=br[b[l]];i++)w[i]++;
for(int i=b[l]+1;i<b[r];i++)la[i]++;
for(int i=bl[b[r]];i<=r;i++)w[i]++;
}

每过 \(S\) 时间我们暴力存下来,\(f[k][i]\) 表示前 \(k\) 个时刻的块,第 \(i\) 个块的 \(F\) 的最大值, \(st[k][i]\) 表示每一个块开头的 \(F\) 值

inline void rec(int k){
for(int i=1;i<=cnt;i++){
for(int j=bl[i];j<=br[i];j++)
f[k][i]=max(f[k][i],w[j]+=la[i]);
st[k][i]=w[bl[i]];la[i]=0;
}
}

对于询问,对于 \(>x\) 的块,我们只关心每一个块的最值,我们直接把 \(f\) 数组拿来用就行了,然后就是 \(x\) 所在块内的修改

我们还是按照 \(Modify\) 函数那样暴力改,但是每改一次需要花费 \(O(S)\) 的时间,复杂度不太对,但实际上这样有很多重复的计算

我们实际上是把某些块做区间加法 , 同一块内的元素相对值不变,所以最值也不会改变,用差分维护一下最值的增量就行了

块外的元素会改变,我们直接把改变之后的值记下来就好了

所以预处理出 \(pre[i],suf[i]\) 表示第 \(i\) 时刻的修改之后,这两个块外的元素所在的块的最值

这样一次修改复杂度就是 \(O(1)\) 的了

#include<bits/stdc++.h>
using namespace std;
const int N=200010,M=510;
int n,m,lis[N],a[N],bc,b[N],bl[N],br[N],p[N],cnt,v[N];
int f[M][M],la[N],w[N],st[M][M],pre[N],suf[N],ed[N];
inline bool comp(int i,int j){return a[i]>a[j];}
inline void Modify(int k,int l,int r){
if(b[l]==b[r]){
for(int i=l;i<=r;i++)w[i]++;
for(int i=bl[b[l]];i<=br[b[l]];i++)pre[k]=max(pre[k],w[i]);
return ;
}
for(int i=l;i<=br[b[l]];i++)w[i]++;
for(int i=bl[b[l]];i<=br[b[l]];i++)pre[k]=max(pre[k],w[i]);
for(int i=b[l]+1;i<b[r];i++)la[i]++;
for(int i=bl[b[r]];i<=r;i++)w[i]++;
for(int i=bl[b[r]];i<=br[b[r]];i++)suf[k]=max(suf[k],w[i]);
}
inline void rec(int k){
for(int i=1;i<=cnt;i++){
for(int j=bl[i];j<=br[i];j++)
f[k][i]=max(f[k][i],w[j]+=la[i]);
st[k][i]=w[bl[i]];la[i]=0;
}
}
inline int qry(int l,int r,int k,int x){
int now=v[k],ret=0;
for(int i=bl[k];i<l;i++)now+=(a[i+m]>=x)-(a[i]>=x);
for(int i=l;i<=r;i++)ret=max(ret,now),now+=(a[i+m]>=x)-(a[i]>=x);
return ret;
}
int main(){
freopen("pp.in","r",stdin);
freopen("pp.out","w",stdout);
scanf("%d%d",&n,&m);bc=sqrt(n);
for(int i=1;i<=n;i++)scanf("%d",&a[i]),lis[i]=a[i],p[i]=i;
sort(lis+1,lis+n+1);
int tp=unique(lis+1,lis+n+1)-lis-1,Q,ans=0;
for(int i=1;i<=n;i++)a[i]=lower_bound(lis+1,lis+tp+1,a[i])-lis;
for(int i=1,t;i<=n;i++)t=b[i]=(i-1)/bc+1,bl[t]=bl[t]?bl[t]:i,br[t]=i;
sort(p+1,p+n+1,comp);cnt=b[n];
for(int i=1;i<=n;i++){
Modify(i,max(1,p[i]-m+1),p[i]);
if(b[i]!=b[i+1])rec(b[i]),ed[b[i]]=a[p[i]];
}
cin>>Q;
while(Q--){
int l,r,x,t=1;
scanf("%d%d%d",&l,&r,&x);
x=lower_bound(lis+1,lis+tp+1,x^ans)-lis;
while(t<cnt && ed[t]>=x)t++;
for(int i=1;i<=cnt;i++)w[i]=f[t-1][i],v[i]=st[t-1][i],la[i]=0;
for(int i=bl[t];i<=br[t] && a[p[i]]>=x;i++){
int L=max(1,p[i]-m+1),R=p[i],A=b[L],B=b[R];
if(A==B)w[A]=pre[i];
else{
w[A]=pre[i];w[B]=suf[i];
la[A+1]++;la[B]--;
}
if(L<=bl[b[l]] && bl[b[l]]<=R)v[b[l]]++;
if(b[l]!=b[r] && L<=bl[b[r]] && bl[b[r]]<=R)v[b[r]]++;
}
for(int i=1;i<=cnt;i++)la[i]+=la[i-1];
int A=b[l],B=b[r];
if(A==B)ans=qry(l,r,A,x);
else{
ans=max(qry(l,br[A],A,x),qry(bl[B],r,B,x));
for(int i=A+1;i<B;i++)ans=max(ans,la[i]+w[i]);
}
ans=m-ans;
printf("%d\n",ans);
}
return 0;
}

Codeforces 543E. Listening to Music的更多相关文章

  1. CF数据结构练习

    1. CF 438D The Child and Sequence 大意: n元素序列, m个操作: 1,询问区间和. 2,区间对m取模. 3,单点修改 维护最大值, 取模时暴力对所有>m的数取 ...

  2. Codeforces Round #164 (Div. 2) E. Playlist 贪心+概率dp

    题目链接: http://codeforces.com/problemset/problem/268/E E. Playlist time limit per test 1 secondmemory ...

  3. Codeforces Round #188 (Div. 2) B. Strings of Power 水题

    B. Strings of Power Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/318/p ...

  4. CodeForces 569A 第六周比赛C踢

    C - C Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u Submit Statu ...

  5. codeforces 569A Music

    codeforces  569A   Music   解题报告 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=88890#pro ...

  6. Codeforces Round #404 (Div. 2) C. Anton and Fairy Tale 二分

    C. Anton and Fairy Tale 题目连接: http://codeforces.com/contest/785/problem/C Description Anton likes to ...

  7. Codeforces Round #289 (Div. 2, ACM ICPC Rules) E. Pretty Song 算贡献+前缀和

    E. Pretty Song time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  8. Codeforces Round #404 (Div. 2) A,B,C,D,E 暴力,暴力,二分,范德蒙恒等式,树状数组+分块

    题目链接:http://codeforces.com/contest/785 A. Anton and Polyhedrons time limit per test 2 seconds memory ...

  9. Codeforces Round #315 (Div. 2) (ABCD题解)

    比赛链接:http://codeforces.com/contest/569 A. Music time limit per test:2 seconds memory limit per test: ...

随机推荐

  1. SQL Server递归实例

    例子一 -- ============================================= -- 根据EID返回其下属的EID,Layer=1表示直接下属,NULL返回所有下属 -- s ...

  2. javascript 获取iframe里页面中元素值的方法 关于contentWindow和contentDocumen

    javascript 获取iframe里页面中元素值的方法 IE方法:document.frames['myFrame'].document.getElementById('test').value; ...

  3. 洛谷P4220 [WC2018]通道(边分治+虚树)

    题面 传送门 题解 代码不就百来行么也不算很长丫 虽然这题随机化贪心就可以过而且速度和正解差不多不过我们还是要好好学正解 前置芝士 边分治 米娜应该都知道点分治是个什么东西,而边分治,顾名思义就是对边 ...

  4. top 常用命令

    参考文档: http://www.cnblogs.com/allen8807/archive/2010/11/10/1874001.html [root@linux ~]# top [-d] | to ...

  5. [译文]casperjs使用说明-选择器

    casperjs的选择器可以在dom下工作,他既支持css也支持xpath. 下面所有的例子都基于这段html代码: <!doctype html> <html> <he ...

  6. ModuleNotFoundError: No module named 'Crypto'

    pycrypto已经舍弃了使用pycryptodome,pip uninstall pycrypto,然后安装pycryptodome,pip install pycryptodome 可能还需要改名 ...

  7. Python全栈-magedu-2018-笔记12

    第三章 - Python 内置数据结构 字典dict key-value键值对的数据的集合 可变的.无序的.key不重复 字典dict定义 初始化 d = dict() 或者 d = {} dict( ...

  8. Advanced-REST-client安装

    下载得到Advanced-REST-client_v3.1.9.zip:链接:http://pan.baidu.com/s/1c0vUnJi 密码:z34d这里要说明下,目前谷歌浏览器是不允许安装非谷 ...

  9. python全栈开发_day7_字符编码,以及文件的基本读取

    一:字符编码 1)什么是字符编码 将人能识别的字符等高级标识符与计算机所能识别的二进制01进行转化,这之间的交流需要一个媒介,进行两种标识符之间的转化. 字节的存储方式为八个二进制位 2)乱码 存放数 ...

  10. 洛谷 P3224 [HNOI2012]永无乡

    题面 永无乡包含 \(n\) 座岛,编号从 \(1\) 到 \(n\) ,每座岛都有自己的独一无二的重要度,按照重要度可以将这 \(n\) 座岛排名,名次用 \(1\) 到 \(n\) 来表示.某些岛 ...