日韩性视频-久久久蜜桃-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 折半搜索的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 欧美激情婷婷 | 日韩有码av | 视频在线观看一区二区三区 | 91国内揄拍国内精品对白 | 欧美成视频 | 亚洲最大黄色 | 亚洲色图一区二区三区 | 久久精品国产亚洲AV无码男同 | 欧美日本韩国在线 | 久久久久影视 | 在线电影一区二区 | 亚洲午夜av| 欧美成人精品在线观看 | 精品一区二区在线看 | 狠狠网站 | 综合激情五月婷婷 | 亚洲啊啊 | 找国产毛片看 | 熟女熟妇伦久久影院毛片一区二区 | 国产免费黄色片 | 9999在线视频 | 亚洲卡一卡二卡三 | 毛片日本| 美女被草出水 | 一区二区三区视频免费视 | 欧美国产日韩在线观看成人 | 97人人干 | 99精品一区二区三区无码吞精 | 精品日韩一区二区三区 | 三级网站免费看 | 久久精品视频网 | 欧美日p视频 | 国产在线观看精品 | 一区三区视频在线观看 | 天天爱天天操 | 国模私拍一区二区 | 超清av在线 | 黄色网免费观看 | 欧美久久久久久久久久久久久久 | 欧美人与动物xxxx | 国产av剧情一区二区三区 | 91精品免费观看 | 手机在线一区 | 欧美性视频在线播放 | 日韩女优网站 | 欧美精品二区三区 | 91黄色小网站 | 亚洲精品成人片在线观看精品字幕 | 国产一区二区视频在线免费观看 | 麻豆国产av超爽剧情系列 | cao久久| 精品少妇人妻av一区二区 | 成人午夜视频免费在线观看 | av收藏小四郎最新地址 | 欧美字幕 | 无遮挡又爽又刺激的视频 | 亚洲在线资源 | av动漫免费观看 | 免费看大片a | 欧美午夜精品理论片 | www国产无套内射com | 欧美性一级片 | 第一色影院 | 无码人妻精品一区二区三 | 视频一区 中文字幕 | 亚洲激情自拍 | 凹凸福利视频 | 国产精品一区在线免费观看 | 无遮挡的裸体按摩的视频 | 日日碰日日摸 | 九九热综合 | 欧美888| 性色av无码久久一区二区三区 | 欧美性猛交xxxⅹ富婆 | 无码精品黑人一区二区三区 | 熟妇人妻一区二区三区四区 | 999久久久| 91日韩精品 | 四虎永久在线精品免费一区二区 | 在线免费观看福利 | 国产91大片 | 久久精品www| 国产精品福利在线观看 | 黄色片在线免费 | 日韩亚洲第一页 | 国产综合精品在线 | 亚洲一区日本 | 男人爽女人下面动态图 | 国产性色av | 九色视频丨porny丨丝袜 | av影视在线观看 | 人妻在客厅被c的呻吟 | 成人二三区| 中文字幕av在线播放 | 区一区二视频 | 日本少妇高潮抽搐 | 国产精品国语对白 | 天天狠狠 | 国产精品国产三级国产普通话对白 |