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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

BZOJ 4823 Luogu P3756 [CQOI2017]老C的方块 (网络流、最小割)

發布時間:2025/3/15 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BZOJ 4823 Luogu P3756 [CQOI2017]老C的方块 (网络流、最小割) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目鏈接

(Luogu) https://www.luogu.org/problem/P3756
(BZOJ) http://lydsy.com/JudgeOnline/problem.php?id=4823

題解

有點神仙的最小割題。
考慮題目里的圖形,如果我們用四種顏色對棋盤進行染色,奇數行依次染\(0,1,2,3,0,1,2,3...\), 偶數行依次染\(3,2,1,0,3,2,1,0...\)則條件可以轉化為不能出現相連的\(4\)個顏色互不相同的塊。
那么可以建一個四層的圖,對于每條兩側都有關鍵點的特殊邊,按照\(S\rightarrow 3\rightarrow 0\rightarrow 1\rightarrow 2\rightarrow T\)的順序連邊,其中\(S\rightarrow 3\)\(3\)色點的點權,\(0\rightarrow 1\)連兩個關鍵點權值的最小值,\(2\rightarrow T\)\(2\)色點的點權。不出現相連的四個顏色互不相同的塊等價于不存在從\(S\)\(T\)的路徑。
然后跑最小割即可。
因為是分層圖,所以dinic跑得很快(復雜度應該是\(O(n\sqrt n)\)),可以通過此題。

代碼

#include<bits/stdc++.h> #define llong long long using namespace std;const int INF = 1e9; namespace NetFlow {const int N = 1e5+2;const int M = 8e5;struct Edge{int v,w,nxt,rev;} e[(M<<1)+3];int fe[N+3];int te[N+3];int dep[N+3];int que[N+3];int n,en,s,t;void addedge(int u,int v,int w){ // printf("addedge %d %d %d\n",u,v,w);en++; e[en].v = v; e[en].w = w;e[en].nxt = fe[u]; fe[u] = en; e[en].rev = en+1;en++; e[en].v = u; e[en].w = 0;e[en].nxt = fe[v]; fe[v] = en; e[en].rev = en-1;}bool bfs(){for(int i=1; i<=n; i++) dep[i] = 0;int head = 1,tail = 1; que[1] = s; dep[s] = 1;while(head<=tail){int u = que[head]; head++;for(int i=fe[u]; i; i=e[i].nxt){int v = e[i].v;if(e[i].w>0 && dep[v]==0){dep[v] = dep[u]+1;if(v==t)return true;tail++; que[tail] = v;}}}return false;}int dfs(int u,int cur){if(u==t||cur==0) {return cur;}int rst = cur;for(int &i=te[u]; i; i=e[i].nxt){int v = e[i].v;if(e[i].w>0 && rst>0 && dep[v]==dep[u]+1){int flow = dfs(v,min(rst,e[i].w));if(flow>0){e[i].w -= flow; rst -= flow;e[e[i].rev].w += flow;if(rst==0) {return cur;}}}}if(rst==cur) {dep[u] = -2;}return cur-rst;}int dinic(int _n,int _s,int _t){n = _n,s = _s,t = _t;int ret = 0;while(bfs()){for(int i=1; i<=n; i++) te[i] = fe[i];memcpy(te,fe,sizeof(int)*(n+1));ret += dfs(s,INF);}return ret;} } using NetFlow::addedge; using NetFlow::dinic;const int N = 1e5; struct Point {int x,y,w; } a[N+3]; map<int,int> mp[N+3]; int id[N+3],clr[N+3]; int n,nx,ny;int getclr(int x,int y) {if(y&1) {return (x-1)&3;}else {return 3-((x-1)&3);} }int main() {scanf("%d%d%d",&nx,&ny,&n);for(int i=1; i<=n; i++){scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].w);mp[a[i].x][a[i].y] = i;}for(int i=1; i<=n; i++){int x = a[i].x,y = a[i].y,clr = getclr(x,y);if(((x+(y<<1))&3)==3 && mp[x+1].count(y)){int j = mp[x+1][y],w = min(a[i].w,a[j].w);if(clr==0){int k = mp[x-1][y]; if(k) {addedge(k+2,i+2,INF);}k = mp[x][y-1]; if(k) {addedge(k+2,i+2,INF);}k = mp[x][y+1]; if(k) {addedge(k+2,i+2,INF);}k = mp[x+2][y]; if(k) {addedge(j+2,k+2,INF);}k = mp[x+1][y+1]; if(k) {addedge(j+2,k+2,INF);}k = mp[x+1][y-1]; if(k) {addedge(j+2,k+2,INF);}addedge(i+2,j+2,w);}else if(clr==1){int k = mp[x+2][y]; if(k) {addedge(k+2,j+2,INF);}k = mp[x+1][y+1]; if(k) {addedge(k+2,j+2,INF);}k = mp[x+1][y-1]; if(k) {addedge(k+2,j+2,INF);}k = mp[x-1][y]; if(k) {addedge(i+2,k+2,INF);}k = mp[x][y-1]; if(k) {addedge(i+2,k+2,INF);}k = mp[x][y+1]; if(k) {addedge(i+2,k+2,INF);}addedge(j+2,i+2,w);}}else if(clr==3){addedge(1,i+2,a[i].w);}else if(clr==2){addedge(i+2,2,a[i].w);}}int ans = dinic(n+2,1,2);printf("%d\n",ans);return 0; }

總結

以上是生活随笔為你收集整理的BZOJ 4823 Luogu P3756 [CQOI2017]老C的方块 (网络流、最小割)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 中文在线一区二区 | 丝袜在线一区 | 中文字幕第一区综合 | jiizzyou欧美2| www.伊人网| 日日精| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚色一区 | 免费人成视频在线 | 又大又粗弄得我出好多水 | 邪恶久久 | 日韩欧美黄 | 久久综合婷婷国产二区高清 | 尤物在线免费视频 | 日韩高清中文字幕 | 亚洲一区二区免费在线观看 | 午夜羞羞影院 | 午夜国产精品视频 | 欧美久久综合网 | 午夜影院免费看 | 99久久精品国产色欲 | 欧美mv日韩mv国产网站 | av毛片网站| 日韩无套无码精品 | 色www亚洲国产张柏芝 | 久久免费一级片 | 高清视频免费在线观看 | 国产一卡二| 少妇av一区二区三区无码 | www.youjizz日本| 诱夫1v1高h | 久久久视频在线观看 | 不卡黄色| 人人人超碰 | 无码熟妇人妻av | 色视频导航 | 亚洲精品在线一区二区 | 色婷婷色综合 | 久操热| 91玉足脚交嫩脚丫在线播放 | 国产精品电影院 | 久久久久综合网 | 久久久久久久一区二区三区 | 韩国毛片基地 | 69精品人人人人 | 久久嫩草视频 | 亚洲毛片在线 | 一本大道熟女人妻中文字幕在线 | 亚洲最大激情网 | 久久影院中文字幕 | 3d动漫啪啪精品一区二区中文字幕 | 香蕉视频黄在线观看 | 漂亮人妻洗澡被公强 日日躁 | 亚洲黄色中文字幕 | av永久在线 | 又粗又大又硬毛片免费看 | av在线三区| 琪琪电影午夜理论片八戒八戒 | 国产黑丝在线视频 | 欧美与黑人午夜性猛交久久久 | 日本黄视频网站 | 福利在线小视频 | 国产污视频 | 成人在线国产精品 | 艳妇臀荡乳欲伦交换h漫 | 免费国产羞羞网站视频 | 免费视频亚洲 | 午夜一级黄色片 | 婷婷一区二区三区 | 美女撒尿无遮挡网站 | 日韩黄| 欧美69影院 | 亚洲精品在线免费观看视频 | 国产精品久久午夜夜伦鲁鲁 | 久久综合桃花网 | 青青射 | 最好看的2019年中文视频 | 国产青青| 亚洲女人av | 琪琪成人 | 丰满人妻av一区二区三区 | 亚洲AV不卡无码一区二区三区 | 丁香伊人 | 亚洲深夜福利视频 | 日韩激情第一页 | 国产成人午夜高潮毛片 | 农民工hdxxxx性中国 | 精品人妻一区二区三区视频 | 99色在线观看 | 日本阿v视频在线观看 | 在线午夜视频 | 激情小说图片视频 | 亚洲av综合色区无码一区爱av | 中国新婚夫妻性猛交 | 老司机免费精品视频 | 中文在线a∨在线 | 日韩在线中文字幕 | 91香蕉视频在线 | 国产精品白嫩极品美女 |