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-12;const int N=200000+10,maxn=8000000+10,inf=0x3f3f3f3f,INF=0x3f3f3f3f3f3f3f3f;struct segtree{ ???ll ma[N<<2]; ???void build(int l,int r,int rt) ???{ ???????ma[rt]=-1; ???????if(l==r)return ; ???????int m=(l+r)>>1; ???????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)>>1; ???????if(pos<=m)update(pos,x,ls); ???????else update(pos,x,rs); ???????ma[rt]=max(ma[rt<<1],ma[rt<<1|1]); ???} ???ll query(int L,int R,int l,int r,int rt) ???{ ???????if(L<=l&&r<=R)return ma[rt]; ???????int m=(l+r)>>1; ???????ll ans=-1; ???????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=200000; ???tree.build(1,n,1); ???ll now=0,ans=0; ???while(m--) ???{ ???????char op[5];ll x; ???????scanf("%s%lld",op,&x); ???????if(op[0]==‘A‘) ???????{ ???????????ll te=(x+ans)%d; ???????????now++; ???????????tree.update(now,te,1,n,1); ???????} ???????else ???????{ ???????????ans=tree.query(now-x+1,now,1,n,1); ???????????printf("%lld\n",ans); ???????} ???} ???return 0;}/****************************************/
1012: [JSOI2008]最大数maxnumber ??线段树
原文地址:https://www.cnblogs.com/acjiumeng/p/8808859.html