日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

P3293 [SCOI2016]美味

發布時間:2023/12/3 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 P3293 [SCOI2016]美味 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

P3293 [SCOI2016]美味

題意:

有n個數組a,現在有m個詢問,每次給出一個b和x,問b xor (a[i] + x)的最大值是多少?

題解:

不難看出01Trie的題目
我們設ans=a[i]+x,我們想要b xor ans的最大值,這個很好說經典套路,如果b的第i位是1,我們就希望ans的第i位是0,此時我們希望ans是張這樣子的:

這樣不難求出a[j]的范圍:a[j]∈[ans-x,ans-x+(1<<i+1)-1]
此時我們就看這個區間內是否存在a[j]滿足情況,也就是看這個區間內是否有數組a存在,主席樹可以解決這個問題
總結:

當b的第i位是1時,若有這樣一個a[i],ans+=0<<i,反之ans+=1<<i
當b的第i位是0時,若有這樣一個a[i],ans+=1<<i,反之ans+=0<<i

代碼:

#include<bits/stdc++.h> #define debug(a,b) printf("%s = %d\n",a,b); using namespace std; typedef long long ll; typedef pair<int, int> PII; clock_t startTime, endTime; //Fe~Jozky const ll INF_ll=1e18; const int INF_int=0x3f3f3f3f; inline ll read(){ll s=0,w=1ll;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1ll;ch=getchar();}while(ch>='0'&&ch<='9') s=s*10ll+((ch-'0')*1ll),ch=getchar();//s=(s<<3)+(s<<1)+(ch^48);return s*w; } void rd_test(){#ifdef ONLINE_JUDGE#elsestartTime = clock(); //計時開始freopen("in.txt","r",stdin);#endif } void Time_test(){#ifdef ONLINE_JUDGE#elseendTime = clock(); //計時結束printf("\n運行時間為:%lfs\n",(double)(endTime - startTime) / CLOCKS_PER_SEC);#endif } const int maxn=5e5+9; int a[maxn],rt,t[maxn<<6],ch[maxn<<5][2],sum[maxn<<5]; int maxx=0; void update(int &now,int pre,int l,int r,int x){if(r<x||l>x)return ;now=++rt;ch[now][0]=ch[pre][0];ch[now][1]=ch[pre][1];sum[now]=sum[pre]+1;if(l==r)return;int mid=l+r>>1;update(ch[now][0],ch[pre][0],l,mid,x);update(ch[now][1],ch[pre][1],mid+1,r,x); } int query(int Ltree,int Rtree,int l,int r,int x,int y){int num=sum[Rtree]-sum[Ltree];if(y<l||x>r||num==0)return 0;if(x<=l&&r<=y)return num;int mid=l+r>>1;return query(ch[Ltree][0],ch[Rtree][0],l,mid,x,y)+query(ch[Ltree][1],ch[Rtree][1],mid+1,r,x,y); } int get(int b,int x,int l,int r){int ans=0;for(int i=30;i>=0;i--){int c=((b>>i)&1);if(c==1&&(!query(t[l-1],t[r],0,maxx,ans-x,ans-x+(1<<i)-1)))ans+=(1<<i);if(c==0&&(query(t[l-1],t[r],0,maxx,ans-x+(1<<i),ans-x+(1<<(i+1))-1)))ans+=(1<<i);}return ans; } int main() {//rd_test();int n,m,q;cin>>n>>q;for(int i=1;i<=n;i++){cin>>a[i];maxx=max(a[i],maxx);}t[0]=0;for(int i=1;i<=n;i++){update(t[i],t[i-1],0,maxx,a[i]);}while(q--){int b,x,l,r;cin>>b>>x>>l>>r;int ans=get(b,x,l,r);printf("%d\n",ans^b);}//Time_test(); }

總結

以上是生活随笔為你收集整理的P3293 [SCOI2016]美味的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。