1012: [JSOI2008]最大数maxnumber 线段树

https://www.lydsy.com/JudgeOnline/problem.php?id=1012

现在请求你维护一个数列,要求提供以下两种操作:1、 查询操作。语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值。限制:L不超过当前数列的长度。2、 插入操作。语法:A n 功能:将n加上t其中t是最近一次查询操作的答案(如果还未执行过查询操作,则t=0),并将所得结果对一个固定的常数D取模,将所得答案插入到数列的末尾。限制:n是非负整数并且在长整范围内。注意:初始时数列是空的,没有一个数。

强制在线,线段树更新即可

//#pragma comment(linker, "/stack:200000000")
//#pragma GCC optimize("Ofast,no-stack-protector")
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")
//#pragma GCC optimize("unroll-loops")
#include<bits/stdc++.h>
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define pi acos(-1.0)
#define ll long long
#define mod 1000000007
#define C 0.5772156649
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#define pil pair<int,ll>
#define pli pair<ll,int>
#define pii pair<int,int>
#define cd complex<double>
#define ull unsigned long long
#define base 1000000000000000000
#define fio ios::sync_with_stdio(false);cin.tie(0) using namespace std; const double g=10.0,eps=1e-;
const int N=+,maxn=+,inf=0x3f3f3f3f,INF=0x3f3f3f3f3f3f3f3f; struct segtree{
ll ma[N<<];
void build(int l,int r,int rt)
{
ma[rt]=-;
if(l==r)return ;
int m=(l+r)>>;
build(ls);build(rs);
}
void update(int pos,ll x,int l,int r,int rt)
{
if(l==r)
{
ma[rt]=x;
return ;
}
int m=(l+r)>>;
if(pos<=m)update(pos,x,ls);
else update(pos,x,rs);
ma[rt]=max(ma[rt<<],ma[rt<<|]);
}
ll query(int L,int R,int l,int r,int rt)
{
if(L<=l&&r<=R)return ma[rt];
int m=(l+r)>>;
ll ans=-;
if(L<=m)ans=max(ans,query(L,R,ls));
if(m<R)ans=max(ans,query(L,R,rs));
return ans;
}
}tree;
int main()
{
ll m,d;scanf("%lld%lld",&m,&d);
int n=;
tree.build(,n,);
ll now=,ans=;
while(m--)
{
char op[];ll x;
scanf("%s%lld",op,&x);
if(op[]=='A')
{
ll te=(x+ans)%d;
now++;
tree.update(now,te,,n,);
}
else
{
ans=tree.query(now-x+,now,,n,);
printf("%lld\n",ans);
}
}
return ;
}
/******************** ********************/
上一篇:Node.js初探之hello world


下一篇:[java] jsoup 解析网页获取省市区域信息