當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
1012: [JSOI2008]最大数maxnumber 线段树
生活随笔
收集整理的這篇文章主要介紹了
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-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; } /****************************************/ View Code?
轉載于:https://www.cnblogs.com/acjiumeng/p/8808859.html
總結
以上是生活随笔為你收集整理的1012: [JSOI2008]最大数maxnumber 线段树的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Extjs遇到的一些问题
- 下一篇: Ajax+Node.js前后端交互最佳入