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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

●BZOJ 1934 [Shoi2007]Vote 善意的投票

發(fā)布時間:2025/4/14 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ●BZOJ 1934 [Shoi2007]Vote 善意的投票 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

題鏈:

http://www.lydsy.com/JudgeOnline/problem.php?id=1934

題解:

題目有點迷。

S向為1的點連邊,為0的點向T連邊,
在有關(guān)系的兩個點之間連雙向邊。
以上邊的容量都為1。
然后求最小割,最小割==最大流,dinic實現(xiàn)。
代碼:

#include<queue> #include<cstdio> #include<cstring> #include<iostream> #define MAXN 350 #define INF 0x3f3f3f3f using namespace std; struct Edge{int to[MAXN*MAXN*2],cap[MAXN*MAXN*2],nxt[MAXN*MAXN*2],head[MAXN],ent;void Init(){ent=2; memset(head,0,sizeof(head));}void Adde(int u,int v,int w){to[ent]=v; cap[ent]=w; nxt[ent]=head[u]; head[u]=ent++;to[ent]=u; cap[ent]=0; nxt[ent]=head[v]; head[v]=ent++;}int Next(bool type,int i){return type?head[i]:nxt[i];} }E; int N,M,T,S; int d[MAXN],cur[MAXN]; bool bfs(){memset(d,0,sizeof(d));queue<int>q; q.push(S); d[S]=1;while(!q.empty()){int u=q.front(); q.pop();for(int i=E.Next(1,u);i;i=E.Next(0,i)){int v=E.to[i];if(d[v]||!E.cap[i]) continue;d[v]=d[u]+1; q.push(v);}}return d[T]; } int dfs(int u,int reflow){if(!reflow||u==T) return reflow;int flowout=0,f;for(int &i=cur[u];i;i=E.Next(0,i)){int v=E.to[i];if(d[v]!=d[u]+1) continue;f=dfs(v,min(reflow,E.cap[i]));reflow-=f; E.cap[i]-=f;flowout+=f; E.cap[i^1]+=f;if(!reflow) break;}if(!flowout) d[u]=0;return flowout; } int Dinic(){int flow=0;while(bfs()){memcpy(cur,E.head,sizeof(E.head));flow+=dfs(S,INF);}return flow; } int main() {scanf("%d%d",&N,&M); S=N+1,T=N+2;E.Init();for(int i=1,x;i<=N;i++){scanf("%d",&x);if(x==1) E.Adde(S,i,1);else E.Adde(i,T,1);}for(int i=1,a,b;i<=M;i++){scanf("%d%d",&a,&b);E.Adde(a,b,1);E.Adde(b,a,1);}int ans=Dinic();printf("%d",ans);return 0; }

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

總結(jié)

以上是生活随笔為你收集整理的●BZOJ 1934 [Shoi2007]Vote 善意的投票的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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