ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

P2393 美味(主席树+贪心)

2020-08-07 15:33:37  阅读:250  来源: 互联网

标签:rt node P2393 rs int mid return 美味 贪心


这道题其实也是最大异或和,我们只需要把后面的加发看作整体之后进行按位贪心

这样答案区间就是一段区间,因此可以用主席树来维护

#include<bits/stdc++.h>
#define getsz(p) (p?p->sz:0)
using namespace std;
typedef long long ll;
const int mod=1e9+7;
const int N=3e5+10;
int a[N];
struct node{
    int l,r;
    int sz;
    node *ls,*rs;
}*rt[N],pool[N*30];
int idx;
node *copynode(node *rt){
    node *p=pool+(++idx);
    pool[idx]=*rt;
    return p;
}
node *insert(node *rt,int l,int r,int x){
    node *p;
    if(rt)
        p=copynode(rt);
    else{
        p=pool+(++idx);
        p->l=l,p->r=r;
    }
    ++p->sz;
    if(p->l==p->r)
        return p;
    int mid=l+r>>1;
    if(x<=mid)
        p->ls=insert(p->ls,l,mid,x);
    else
        p->rs=insert(p->rs,mid+1,r,x);
    return p;
}
int query(node* p,int x){
    if(x < 0) return 0;
    if(!p) return 0;
    if(p->r <= x) return p->sz;

    int mid = (p->l + p->r)/2;
    if(x <= mid) return query(p->ls, x);
    else return getsz(p->ls) + query(p->rs,x);
}
int main(){
    ios::sync_with_stdio(false);
    int n,m;
    cin>>n>>m;
    int i;
    int x=100000;
    for(i=1;i<=n;i++){
        cin>>a[i];
        rt[i]=insert(rt[i-1],1,x,a[i]);
    }
    int b,l,r;
    while(m--){
        cin>>b>>x>>l>>r;
        int ans = 0;
        for(int i=20;i>=0;i--){
            if((b>>i)&1){
                n = query(rt[r], ans-x+(1<<i)-1) - query(rt[r], ans-x-1);
                n -= query(rt[l-1], ans-x+(1<<i)-1) - query(rt[l-1],  ans-x-1);
                if(n==0) ans += (1<<i);
            }
            else{
                n = query(rt[r],  ans-x+(1<<(i+1))-1) - query(rt[r], ans-x+(1<<i)-1);
                n -= query(rt[l-1],  ans-x+(1<<(i+1))-1) - query(rt[l-1],ans-x+(1<<i)-1);
                if(n) ans += (1<<i);
            }
        }
        cout<<(ans^b)<<endl;
    }
    return 0;
}
View Code

 

标签:rt,node,P2393,rs,int,mid,return,美味,贪心
来源: https://www.cnblogs.com/ctyakwf/p/13453148.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有