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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

P3067 [USACO12OPEN]Balanced Cow Subsets G 折半搜索

發布時間:2023/12/4 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 P3067 [USACO12OPEN]Balanced Cow Subsets G 折半搜索 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

傳送門

文章目錄

  • 目錄
    • 題意:
    • 思路:

目錄

題意:

給你nnn個數,從中任意選出一組數,使這些數能分成和相等的兩組,問有多少種選數方案。

2≤n≤20,1≤ai≤1e92\le n\le 20,1\le a_i\le 1e92n20,1ai?1e9

思路:

注意審題,是選出一組能分成兩組和相等的即可,也就是說如果是同一組但是分成兩個部分的時候有多種方案,那么也算一種。

看到nnn很小,不難想到爆搜,但是每個數有三種情況,復雜度3n3^n3n,但是我們可以使用meetinmiddlemeet\ \ in\ \ middlemeet??in??middle先搜一半,讓后對于另一半直接使用其搜出來的信息,由于對于每一個選出來數相同的方案都視為一個方案,所以對于每個狀態我們需要記一個state代表當前選了哪幾個,讓后去重即可。

考慮如何計算方案?假設當前兩邊差值的絕對值是xxx,那么需要另一半兩邊插值絕對值也為xxx,是否只需要加入另一半插值也為xxx的方案即可?答案是否定的,還需要判斷當前這一半狀態與另一半狀態拼起來是否已經計算過,所以需要存下來遍歷,這樣復雜度有點高,但是吸氧能過。。

#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; typedef pair<LL,LL> PII;int n; int a[N]; map<LL,vector<int>>mp; map<pair<LL,LL>,int>st,vis;void dfs(int u,LL l,LL r,LL state) {if(u>=n/2) {LL now=abs(r-l);if(st.count({state,now})) return;st[{state,now}]=1;mp[now].pb(state);//cout<<now<<"**"<<l<<' '<<r<<endl;return;}dfs(u+1,l,r,state);dfs(u+1,l+a[u],r,state+(1<<u));dfs(u+1,l,r+a[u],state+(1<<u)); }LL ans=0; void solve(int u,LL l,LL r,LL state) {if(u==n) {LL now=abs(l-r);if(st.count({state,now})) return;st[{state,now}]=1;//ans+=mp[now];for(auto x:mp[now]) {if(vis.count({x,state})) continue;vis[{x,state}]=1;ans++;}return;}solve(u+1,l,r,state);solve(u+1,l+a[u],r,state+(1<<u));solve(u+1,l,r+a[u],state+(1<<u)); }void solve() {scanf("%d",&n);for(int i=0;i<n;i++) scanf("%d",&a[i]);if(n==1) {puts("0");return;}dfs(0,0,0,0);st.clear(); vis[{0,0}]=1;//for(auto x:mp) cout<<x.X<<' '<<x.Y<<endl;solve(n/2,0,0,0);printf("%lld\n",(ans)); }int main() {int _=1;while(_--) {solve();}return 0; }

總結

以上是生活随笔為你收集整理的P3067 [USACO12OPEN]Balanced Cow Subsets G 折半搜索的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 欧美黄色a级大片 | 蜜臀久久99精品久久久 | a毛片| 视频一区 国产 | 啦啦啦视频在线观看 | 亲子乱aⅴ一区二区三区 | 亚洲一久久 | 欧美午夜精品一区二区蜜桃 | 爱情岛论坛av | 高清毛片aaaaaaaaa郊外 | 日本三级2019 | 又大又长粗又爽又黄少妇视频 | 不卡的av片| 欧洲一区二区三区在线 | 高清一区二区 | 中出一区 | 久久免费看少妇高潮v片特黄 | 中文字幕在线欧美 | 中文字幕精品久久 | 少妇紧身牛仔裤裤啪啪 | 综合网av | 看一级黄色大片 | 婷婷av在线| 欧美午夜精品一区二区蜜桃 | 丰满护士巨好爽好大乳 | 94av | 97影视| 久久久久久久久久国产精品 | 在线播放你懂的 | 日韩午夜激情电影 | 美女极度色诱图片www视频 | 日本人的性生活视频 | 一区二区三区在线观看 | av片免费在线 | 久久精品国产精品亚洲色婷婷 | 亚洲av成人精品毛片 | 天天搞天天搞 | 日韩精品一区二区三区不卡 | 免费又黄又爽又色的视频 | 日本a视频 | 91av观看 | 91av视频在线免费观看 | 亚洲日本视频在线观看 | 中文字幕成人在线观看 | 91免费在线视频 | 黄色a级免费 | 亚欧精品在线观看 | 婷婷九月丁香 | 国产精品一区二区三区四 | 美女视频黄a视频全免费观看 | 一区二区手机在线 | 六月丁香综合网 | 依人成人综合网 | 精品午夜一区二区三区 | 国产在线激情 | 一区二区三区www污污污网站 | 国产美女精品 | 噜噜狠狠狠狠综合久久 | 户外露出一区二区三区 | 国产精品另类 | 精品国产xxx | 婷婷tv| 黑鬼大战白妞高潮喷白浆 | 黄色a视频 | 午夜网页 | 黄色网www | 日本xx视频免费观看 | 高清久久久 | 欧美被狂躁喷白浆精品 | 国产视频你懂得 | 黄色一级片在线看 | 67194成人在线 | 久一在线视频 | 色干综合| 邪恶久久 | 色女人av| 男人的天堂免费视频 | 国产91精选 | 五月天三级 | 人人爱操 | 快播视频在线观看 | 国产精品久久久久久久蜜臀 | 黄色录象片 | 精品一区三区 | 可以免费看的黄色网址 | av在线.com | 男人天堂伊人 | 小珊的性放荡羞辱日记 | 国产suv精品一区二区69 | 夜夜爽日日澡人人添 | 色噜噜在线播放 | 国产精品二区一区二区aⅴ污介绍 | 男女草逼| 丰满少妇xbxb毛片日本 | 黄色片在线观看免费 | √资源天堂中文在线视频 | 琪琪av在线 | 日韩一区二区免费在线观看 | 午夜毛片电影 |