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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

【BZOJ3866】The Romantic Hero DP

發(fā)布時間:2023/12/20 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【BZOJ3866】The Romantic Hero DP 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

【BZOJ3866】The Romantic Hero

題意:一個序列,從中選取兩個子序列S和T,滿足S中所有元素都在T左邊,并且S中所有數(shù)的xor和=T中所有數(shù)的and和,求方案數(shù)。n<=1000,ai<1024

題解:用s[i][j]表示從1-i中選出一些數(shù),最后一個數(shù)是i,xor和為j的方案數(shù)。轉(zhuǎn)移時用前綴和優(yōu)化即可。用t[i][j]表示從i-n中選出一些數(shù),最左邊的數(shù)是i,and和為j的方案數(shù),轉(zhuǎn)移同理。計算答案的時候,用t[i][j]*s[1...i-1][j]即可。

?

#include <cstdio> #include <cstring> #include <iostream> using namespace std; const int P=1000000007; typedef long long ll; int n; ll ans; int ss[1010][1050],s[1050],t[1050],st[1010][1050],v[1010]; inline int rd() {int ret=0,f=1; char gc=getchar();while(gc<'0'||gc>'9') {if(gc=='-')f=-f; gc=getchar();}while(gc>='0'&&gc<='9') ret=ret*10+gc-'0',gc=getchar();return ret*f; } void work() {n=rd(),ans=0;int i,j;for(i=1;i<=n;i++) v[i]=rd();memset(ss,0,sizeof(ss)),memset(st,0,sizeof(st));for(i=1;i<=n;i++){memset(s,0,sizeof(s)),s[v[i]]=1;for(j=0;j<1024;j++) s[j^v[i]]=(s[j^v[i]]+ss[i-1][j])%P;for(j=0;j<1024;j++) ss[i][j]=(ss[i-1][j]+s[j])%P;}for(i=n;i>=1;i--){memset(t,0,sizeof(t)),t[v[i]]=1;for(j=0;j<1024;j++) t[j&v[i]]=(t[j&v[i]]+st[i+1][j])%P;for(j=0;j<1024;j++) ans=(ans+(ll)ss[i-1][j]*t[j])%P,st[i][j]=(st[i+1][j]+t[j])%P;}printf("%lld\n",ans); } int main() {int T=rd();while(T--) work();return 0; }//2 3 1 2 3 4 1 2 3 3

?

轉(zhuǎn)載于:https://www.cnblogs.com/CQzhangyu/p/7501166.html

總結(jié)

以上是生活随笔為你收集整理的【BZOJ3866】The Romantic Hero DP的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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