一道比较奇怪的线段树。。。如题操作就好了。。。
#include<bits/stdc++.h>
using namespace std;
#define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1
const int maxn = 200001;
int num[maxn<<2];
int d,m,len,t;
void build(int l,int r,int rt)
{
num[rt]=-0x3f3f3f3f;
if (l==r)
return;
int mid=(l+r)>>1;
build(lson);
build(rson);
}
void update(int l,int r,int rt,int i,int j)
{
if(l==r)
{
num[rt]=j;
return;
}
int mid=(l+r)>>1;
if (i<=mid)
update(lson,i,j);
else
update(rson,i,j);
num[rt]=max(num[rt<<1],num[rt<<1|1]);
}
int query(int l,int r,int rt,int i,int j)
{
if (i<=l && r<=j)
return num[rt];
int mid=(l+r)>>1,res=-0x3f3f3f3f;
if (i<=mid)
res=max(res,query(lson,i,j));
if (j>mid)
res=max(res,query(rson,i,j));
return res;
}
int main ()
{
scanf ("%d%d",&m,&d);
build(1,maxn,1);
len = t = 0;
for(int b=1;b<=m;++b)
{
char c;
int i;
cin>>c;
scanf("%d",&i);
if(c=='A')
{
len++;
update(1,maxn,1,len,(i+t)%d);
}
else
{
t=query(1,maxn,1,len-i+1,len);
printf ("%d\n",t);
}
}
return 0;
}