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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

CF 1635 D. Infinite Set 思维 + 二进制

發(fā)布時(shí)間:2023/12/4 编程问答 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 CF 1635 D. Infinite Set 思维 + 二进制 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

  • 題意
  • 思路

傳送門(mén)

題意

給你一個(gè)集合SSS,初始集合內(nèi)含有nnn個(gè)數(shù),讓后按照一下三個(gè)規(guī)則無(wú)限的向集合中添加數(shù):

  • 對(duì)于所有的1≤i≤n,x=ai1\le i\le n,x=a_i1in,x=ai?都在集合中。
  • 對(duì)于所有的x=2y+1,y∈Sx=2y+1,y\in Sx=2y+1,yS,都可以將xxx加入集合。
  • 對(duì)于所有的x=4y,y∈Sx=4y,y\in Sx=4y,yS都可以將x加入集合。
  • 問(wèn)集合中小于2p2^p2p的數(shù)有多少個(gè),對(duì)1e9+71e9+71e9+7取模。

    1≤n,p≤2e5,1≤ai≤1e91\le n,p\le 2e5,1\le a_i\le 1e91n,p2e5,1ai?1e9

    思路

    ppp2e52e52e5級(jí)別的,肯定是要找規(guī)律了,考慮兩中操作對(duì)于二進(jìn)制來(lái)說(shuō)都發(fā)生了什么:

  • 對(duì)于第二種操作,無(wú)非就是在二進(jìn)制序列的最后加上了一個(gè)111,長(zhǎng)度增加111
  • 對(duì)于第三種操作,無(wú)非就是在二進(jìn)制序列的最后加上了兩個(gè)000,長(zhǎng)度增加222
  • 而小于2p2^p2p也就是小于等于ppp個(gè)111,所以就可以轉(zhuǎn)換成將某個(gè)數(shù)xxx的二進(jìn)制長(zhǎng)度加到ppp的方案數(shù),也就是個(gè)數(shù)了,這個(gè)可以由dp[i]=dp[i?1]+dp[i?2]dp[i]=dp[i-1]+dp[i-2]dp[i]=dp[i?1]+dp[i?2]的經(jīng)典dpdpdp來(lái)得到,讓后做一個(gè)前綴和,算一下dp[p?len(x)]dp[p-len(x)]dp[p?len(x)]就是答案了。

    但是這樣直接來(lái)會(huì)有重復(fù)的情況,但是我們發(fā)現(xiàn)如果找到根的話,讓后就可以根據(jù)根來(lái)去重,對(duì)于每個(gè)數(shù),能構(gòu)成他的數(shù)最多有lognlognlogn個(gè),所以我們直接找到他的所有父親,拿mapmapmap去重一下即可。

    由于用到了mapmapmap,所以復(fù)雜度O(nlog2n)O(nlog^2n)O(nlog2n)

    #include<bits/stdc++.h> #define X first #define Y second #define L (u<<1) #define R (u<<1|1) #define Mid (tr[u].l+tr[u].r>>1) #define pb push_back using namespace std;const int N=1000010,INF=0x3f3f3f3f,mod=1e9+7; typedef long long LL;int n,p; int f[N],a[N];void solve() {f[1]=1; f[2]=2;for(int i=3;i<N;i++) f[i]=(f[i-1]+f[i-2])%mod;for(int i=2;i<N;i++) (f[i]+=f[i-1])%=mod;map<int,int>mp;scanf("%d%d",&n,&p);for(int i=1;i<=n;i++) {scanf("%d",&a[i]);}sort(a+1,a+1+n);LL ans=0;for(int i=1;i<=n;i++) {int val=a[i];bool flag=true;while(val) {if(mp.count(val)) flag=false;if(val&1) val>>=1;else if(val&3) break;else val>>=2;}if(!flag) continue;ans++;int cnt=(int)log2(a[i])+1;ans+=f[max(0,p-cnt)];if(p<cnt) ans--;ans+=mod;ans%=mod;mp[a[i]]=1;}printf("%lld\n",ans); }int main() {int _=1;while(_--) {solve();}return 0; }

    總結(jié)

    以上是生活随笔為你收集整理的CF 1635 D. Infinite Set 思维 + 二进制的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。