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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

AtCoder AGC034D Manhattan Max Matching (网络流)

發布時間:2025/3/15 编程问答 14 豆豆
生活随笔 收集整理的這篇文章主要介紹了 AtCoder AGC034D Manhattan Max Matching (网络流) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目鏈接

https://atcoder.jp/contests/agc034/tasks/agc034_d

題解

降智了沒想出來建圖……(不過這場是真的DE放反了)
注意到曼哈頓距離有一個重要的性質: 合法的最大,也就是對于任意維數兩個點的曼哈頓距離而言,假設我們把每個絕對值符號任意地改變成正號或者負號,那么合法的(實際的)曼哈頓距離是這所有值里最大的。證明顯然。
那么既然我們求的是最大距離和,就可以忽略合不合法的問題,四種拆絕對值的方法不對連接的兩個點的坐標有要求。
考慮費用流建圖,建兩排點分別表示兩種球,然后在中間建四個點代表四種匹配方式,兩邊的每個點和中間的每個點連對應匹配方式的權值,求最大費用最大流即可。
時間復雜度\(O(MFMC(n,10n))\), 似乎費用流算法的復雜度可以被估計為\(O(mC\log m)\)其中\(C\)為最大流量,而這里最大流量是\(O(S)\)的,故復雜度\(O(nS\log n)\).
題解里說可以模擬費用流做到\(O(S\log n)\)... 瑟瑟發抖

代碼

#include<bits/stdc++.h> #define llong long long #define mkpr make_pair #define riterator reverse_iterator using namespace std;inline int read() {int x = 0,f = 1; char ch = getchar();for(;!isdigit(ch);ch=getchar()) {if(ch=='-') f = -1;}for(; isdigit(ch);ch=getchar()) {x = x*10+ch-48;}return x*f; }const llong INF = 1e12;namespace NetFlow {const int N = 2006;const int M = 10000;struct AEdge{int u,v,wl,wr; llong c;} ae[M+3];struct Edge{int u,v,nxt,w; llong c;} e[(M<<1)+3];int fe[N+3];llong dis[N+3];int que[N+5];bool inq[N+3];int lst[N+3];int n,m,en,s,t; llong mf,mc;void addedge(int u,int v,int w,llong c){ // printf("addedge %d %d %d %lld\n",u,v,w,c);en++; e[en].u = u,e[en].v = v,e[en].w = w,e[en].c = c;e[en].nxt = fe[u]; fe[u] = en;en++; e[en].u = v,e[en].v = u,e[en].w = 0,e[en].c = -c;e[en].nxt = fe[v]; fe[v] = en;}bool spfa(){for(int i=1; i<=n; i++) dis[i] = -INF;int hd = 1,tl = 2; que[1] = s; dis[1] = 0;while(hd!=tl){int u = que[hd]; hd++; if(hd>n+1) hd-=n+1;for(int i=fe[u]; i; i=e[i].nxt){int v = e[i].v;if(e[i].w>0&&dis[e[i].v]<dis[u]+e[i].c){dis[e[i].v] = dis[u]+e[i].c; lst[e[i].v] = i;if(!inq[e[i].v]){inq[e[i].v] = true;que[tl] = e[i].v; tl++; if(tl>n+1) tl-=n+1;}}}inq[u] = false;}return dis[t]!=-INF;}void calcflow(){int flow = 1e5;for(int u=t; u!=s; u=e[lst[u]].u){flow = min(flow,e[lst[u]].w);}for(int u=t; u!=s; u=e[lst[u]].u){e[lst[u]].w -= flow; e[lst[u]^1].w += flow;}mf += flow; mc += 1ll*flow*dis[t];}llong mfmc(int _n,int _s,int _t){n = _n,s = _s,t = _t; mf = 0,mc = 0ll;while(spfa()) {calcflow();} return mc;} } using NetFlow::addedge;const int N = 1000; struct Point {int x,y,cnt; } a[N+3],b[N+3]; int n;int main() {NetFlow::en = 1;scanf("%d",&n);for(int i=1; i<=n; i++) scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].cnt);for(int i=1; i<=n; i++) scanf("%d%d%d",&b[i].x,&b[i].y,&b[i].cnt);for(int i=1; i<=n; i++){addedge(1,i+6,a[i].cnt,0);addedge(i+6,3,a[i].cnt,-a[i].x-a[i].y);addedge(i+6,4,a[i].cnt,-a[i].x+a[i].y);addedge(i+6,5,a[i].cnt,a[i].x-a[i].y);addedge(i+6,6,a[i].cnt,a[i].x+a[i].y);}for(int i=1; i<=n; i++){addedge(i+n+6,2,b[i].cnt,0);addedge(3,i+n+6,b[i].cnt,b[i].x+b[i].y);addedge(4,i+n+6,b[i].cnt,b[i].x-b[i].y);addedge(5,i+n+6,b[i].cnt,-b[i].x+b[i].y);addedge(6,i+n+6,b[i].cnt,-b[i].x-b[i].y);}llong ans = NetFlow::mfmc(n+n+6,1,2);printf("%lld\n",ans);return 0; }

總結

以上是生活随笔為你收集整理的AtCoder AGC034D Manhattan Max Matching (网络流)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 偷偷久久 | 亚洲av久久久噜噜噜噜 | 精品人妻一区二区三区免费看 | 99热亚洲 | 正在播放老肥熟妇露脸 | 91在线免费看片 | 人妖和人妖互交性xxxx视频 | 日本不卡专区 | 绯色av一区二区三区高清 | 椎名由奈av一区二区三区 | 欧美福利片在线观看 | 色播导航| 88av网| 丰满人妻一区二区三区53 | 亚洲女优一区 | 久久国产免费看 | 黄色国产视频网站 | 亚洲中字幕 | 日本国产中文字幕 | 免费在线黄色网址 | 韩国视频一区二区三区 | 国产无套内射普通话对白 | 怡红院成人影院 | 国产在线精品成人欧美 | 精品网站999 | 999热视频 | 黄色小网站在线观看 | 人人干干 | 激情自拍视频 | 日韩视频区 | 日本欧美久久久久免费播放网 | 污黄网站在线观看 | 国产精品伦一区 | 97人妻人人揉人人躁人人 | 黄色永久视频 | 懂色一区二区三区 | 中日一级片 | 国产原创麻豆 | 琪琪色在线视频 | 毛片久久久久久久 | 久热精品视频在线 | 亚洲黄a | 久久超碰精品 | 亚洲精品乱码久久久久久不卡 | 99精品视频一区二区 | 高h喷水荡肉少妇爽多p视频 | 色眯眯影院 | 熟女自拍一区 | 成人69视频 | 日本高清视频www | 欧美另类第一页 | 去毛片| 欧美经典一区二区三区 | 三级免费黄录像 | 中国美女一级看片 | 久久午夜片 | 色哟哟一区二区三区四区 | 亚洲最大网 | 久久久久久综合网 | 97精品人妻一区二区 | jizz俄罗斯| 久草免费福利视频 | 日本少妇高潮喷水xxxxxxx | 日本激情视频在线 | 69视频一区 | 91羞羞网站 | 青青草视频在线观看免费 | 风间由美在线观看 | www.久热 | 免费成人深夜夜国外 | 日韩午夜一区 | 日本黄色免费在线观看 | 日本大尺度吃奶做爰视频 | 亚洲日本成人在线观看 | 久久久久噜噜噜亚洲熟女综合 | 青青草手机在线观看 | 久久久久久国产精品免费播放 | 未满十八岁勿进 | 久久久国产精品黄毛片 | 日韩理论在线观看 | 亚洲欧美日韩在线 | 女人被男人躁得好爽免费视频 | 538在线精品视频 | 午夜精品在线观看 | 95在线视频| 韩国三级hd中文字幕有哪些 | 99久久久久久 | 天天综合国产 | 久久久久久久久免费看无码 | 中文字幕无码乱码人妻日韩精品 | 调教女m荡骚贱淫故事 | 国产精品久久久久久久久久免费看 | 日本欧美一本 | 日韩av自拍偷拍 | 侵犯女教师一区二区三区 | 北岛玲一区二区 | 看片在线 | 日韩黄色片| 天天干天天操天天摸 |