zoukankan      html  css  js  c++  java
  • SP3946 MKTHNUM

    思路

    整体二分的板子题,没什么思路好说

    代码

    #include <cstdio>
    #include <algorithm>
    #include <cstring>
    using namespace std;
    struct Query{
        int type,pos,val,l,r,k,aid;
    }Query[110000],lx[110000],rx[110000];
    int ans[10000],n,m,qid,aid,minx=0x3f3f3f3f,maxx=-0x3f3f3f3f;
    namespace BIT{
        int bit[110000];
        int lowbit(int x){
            return x&(-x);
        }
        void add(int pos,int val){
            while(pos<=n){
                bit[pos]+=val;
                pos+=lowbit(pos);
            }
        }
        int query(int pos){
            int ans=0;
            while(pos){
                ans+=bit[pos];
                pos-=lowbit(pos);
            }
            return ans;
        }
    };
    void divide(int L,int R,int l,int r){//L,R 值域 l,r 操作序列
        if(l>r)
            return;
        int lt=0,rt=0;
        if(L==R){
            for(int i=l;i<=r;i++)
                if(Query[i].aid)
                    ans[Query[i].aid]=L;
            return;
        }
        int mid=(L+R)>>1;
        for(int i=l;i<=r;i++){
            if(Query[i].type==1){//修改
                if(Query[i].val<=mid){
                    BIT::add(Query[i].pos,1);
                    lx[++lt]=Query[i];
                }
                else
                    rx[++rt]=Query[i];            
            }
            else{//查询
                int cnt=BIT::query(Query[i].r)-BIT::query(Query[i].l-1);
                if(cnt<Query[i].k){
                    Query[i].k-=cnt;
                    rx[++rt]=Query[i];
                }
                else
                    lx[++lt]=Query[i];
            }
        }
        for(int i=l;i<=r;i++)
            if(Query[i].type==1&&Query[i].val<=mid)
                BIT::add(Query[i].pos,-1);
        for(int i=1;i<=lt;i++)
            Query[l+i-1]=lx[i];
        for(int i=1;i<=rt;i++)
            Query[l+lt+i-1]=rx[i];
        divide(L,mid,l,l+lt-1);
        divide(mid+1,R,l+lt,r);
    }
    int main(){
        scanf("%d %d",&n,&m);
        for(int i=1;i<=n;i++){
            int x;
            scanf("%d",&x);
            Query[++qid].pos=i;
            Query[qid].type=1;
            Query[qid].val=x;
            maxx=max(maxx,x);
            minx=min(minx,x);
        }
        for(int i=1;i<=m;i++){
            Query[++qid].type=2;
            scanf("%d %d %d",&Query[qid].l,&Query[qid].r,&Query[qid].k);
            Query[qid].aid=++aid;
        }
        divide(minx,maxx,1,qid);
        for(int i=1;i<=m;i++)
            printf("%d
    ",ans[i]);
        return 0;
    }
    
  • 相关阅读:
    基于XMPP的即时通信系统的建立 — XMPP IQ详解
    XMPPManager 解析
    Xcode 工程文件“.xcodeproj”文件夹解析
    Description &&debugDescription && runtime(debug模式下调试model)
    day04作业
    数字、字符串、列表、字典,jieba库,wordcloud词云
    if,for,异常,random模块,计算圆周率
    day03
    day02
    计算机基础
  • 原文地址:https://www.cnblogs.com/dreagonm/p/10126344.html
Copyright © 2011-2022 走看看