• 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
    ",ans);
            }
        }
        return 0;
    }
    /********************
    
    ********************/
    View Code
  • 相关阅读:
    关于wepy小程序图片显示问题
    输入地址到页面显示发生了写什么?
    一次Debug过程的思考
    一次冗长繁琐的排错经历
    PHP内核探索之变量(7)- 不平凡的字符串
    PHP内核探索之变量(6)- 后续内核探索系列大纲备忘
    PHP内核探索之变量(5)- session的基本原理
    PHP内核探索之变量(4)- 数组操作
    PHP内核探索之变量(3)- hash table
    PHP内核探索之变量(2)-理解引用
  • 原文地址:https://www.cnblogs.com/acjiumeng/p/8808859.html
Copyright © 2020-2023  润新知