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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

hdu4940 有上下界的无源可行流判断

發布時間:2025/6/17 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hdu4940 有上下界的无源可行流判断 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題意:
? ? ? 給你一個強連通圖,然后問你是否可以找到任意滿足條件的集合S,S是非空集合,T是S的補集,滿足sum(D[i ,j]) <= sum(D[j,i] + B[j,i]) i屬于S集合,j屬于T集合(其實也就暗示了i,j是S,T的割邊)。

思路:

? ? ? ?無源匯上下流可行流判斷問題,首先題目給的圖是一個強連通圖,為了方便理解,我們假設這個圖只有兩個點,a,b,那么肯定也只有兩條邊,a->b ,b->a,那么我們可以直接建邊a->b(下界 D 上界 B + D) b->a(下界 D 上界 B + D)這樣跑一遍上下流之后如果存在可行流,那么就存在一個a,b之間的循環流(循環流的大小我們不用關心,我們只關心是否存在),那么就會有這樣的結論,a->b的D(下限)一定小于等于b->a 的D+B(上限),同時 b->a的D(下限) 一定小于等于a->b的 D+B(上限),所以無論是a,還是b都可以充當S集合。so如果整個圖中任意兩個集合都這樣就顯然可以滿足題意了。


#include<stdio.h> #include<string.h> #include<queue>#define N_node 220 #define N_edge 33000 #define INF 1000000000 using namespace std;typedef struct {int to ,next ,cost; }STAR;typedef struct {int x ,t; }DEP;STAR E[N_edge]; DEP xin ,tou; int list[N_node] ,listt[N_node] ,tot; int deep[N_node] ,sum_must;void add(int a ,int b ,int c) {E[++tot].to = b;E[tot].cost = c;E[tot].next = list[a];list[a] = tot;E[++tot].to = a;E[tot].cost = 0;E[tot].next = list[b];list[b] = tot; }void ADD(int a ,int b ,int c ,int d ,int ss ,int tt) {add(a ,b ,d - c);add(a ,tt ,c);add(ss ,b ,c);sum_must += c; }int minn(int x ,int y) {return x < y ? x : y; }bool BFS_Deep(int s ,int t ,int n) {xin.x = s ,xin.t = 0;queue<DEP>q;q.push(xin);memset(deep ,255 ,sizeof(deep));deep[s] = 0;while(!q.empty()){tou = q.front();q.pop();for(int k = list[tou.x] ;k ;k = E[k].next){xin.x = E[k].to;xin.t = tou.t + 1;if(deep[xin.x] != -1 || !E[k].cost)continue;deep[xin.x] = xin.t;q.push(xin);}}for(int i = 0 ;i <= n ;i ++)listt[i] = list[i];return deep[t] != -1; }int DFS_Flow(int s ,int t ,int flow) {if(s == t) return flow;int nowflow = 0;for(int k = listt[s] ;k ;k = E[k].next){listt[s] = k;int to = E[k].to;int c = E[k].cost;if(deep[to] != deep[s] + 1 || !c)continue;int tmp = DFS_Flow(to ,t ,minn(c ,flow - nowflow));nowflow += tmp;E[k].cost -= tmp;E[k^1].cost += tmp;if(nowflow == flow)break;}if(!nowflow) deep[s] = 0;return nowflow; }int DINIC(int s ,int t ,int n) {int ans = 0;while(BFS_Deep(s ,t ,n)){ans += DFS_Flow(s ,t ,INF);}return ans; }int main () {int t ,n ,m ,i ,a ,b ,c ,d ,cas = 1;scanf("%d" ,&t);while(t--){scanf("%d %d" ,&n ,&m);int ss = 0 ,tt = n + 1;memset(list ,0 ,sizeof(list));tot = 1 ,sum_must = 0;for(i = 1 ;i <= m ;i ++){scanf("%d %d %d %d" ,&a ,&b ,&c ,&d);ADD(a ,b ,c ,c + d ,ss ,tt);}printf("Case #%d: " ,cas ++);sum_must == DINIC(ss ,tt ,tt) ? puts("happy") : puts("unhappy");}return 0; }

總結

以上是生活随笔為你收集整理的hdu4940 有上下界的无源可行流判断的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 亚洲激情av在线 | 国产一区二区av | 亚洲天堂自拍偷拍 | 天堂在线 | 国产麻豆免费观看 | 手机在线观看免费av | 激情插插插 | 黑人无套内谢中国美女 | 久久精品视频一区 | 国产亚洲精久久久久久无码77777 | 欧美日韩在线成人 | 免费观看国产视频 | 91亚洲精品国偷拍自产在线观看 | 肉丝美足丝袜一区二区三区四 | 韩国女同性做爰三级 | 91日日夜夜| 91性色| 日韩在线三级 | 日本草草影院 | 午夜三级福利 | 日韩黄色高清视频 | 欧美日韩在线观看视频 | 一区二区免费看 | 日日夜夜草 | 潘金莲一级淫片a.aaaaa播放 | 免费观看成年人视频 | 国产第一页第二页 | 国产精品羞羞答答在线观看 | 波多野结衣中文在线 | 无遮挡又爽又刺激的视频 | av高清在线免费观看 | 韩国av在线免费观看 | 丝袜美腿亚洲一区二区图片 | 二区免费视频 | 成人短视频在线播放 | 丰满少妇被猛烈进入 | 久久久久久久偷拍 | 国产精品拍拍 | 在线免费视频一区二区 | 日本一本二本三区免费 | 日本精品二区 | 国产白丝一区二区三区 | 日韩黄色片在线观看 | 无码少妇一区二区 | 97无码精品人妻 | 人人澡人人看 | 欧美撒尿777hd撒尿 | 神秘电影永久入口 | 丁香五香天堂 | 久久久成 | 国产在线久 | 九九热8 | 日韩久久久久久 | 无码无遮挡又大又爽又黄的视频 | 黄色一毛片 | 免费无码毛片一区二三区 | 性生活三级视频 | 国产chinesehd精品露脸 | 日韩精品在线第一页 | 国产精品久久久久影院色老大 | 人妻互换一二三区激情视频 | 国产免费观看一区 | 五月婷中文字幕 | 国产jjizz一区二区三区视频 | 中文字幕一本 | 黑丝美女一区二区 | 久久久蜜桃一区二区 | www.69视频 | 日韩欧美色 | 一区二区三区偷拍 | 91中文视频 | 国产欧美日韩综合 | 高潮喷水一区二区三区 | 国产精品主播 | www.久久99| 女人扒开腿让男人桶爽 | 伊人久久精品一区二区三区 | 精射女上司 | ass亚洲熟妇毛耸耸pics | 国产又色又爽又黄又免费 | 热热热av | 国产精品偷拍 | 久久免费看少妇高潮 | 国产九九精品 | 天堂在线中文网 | 国产精品美女一区 | 亚洲精品视 | 成人免费久久 | 精品日本一区二区 | 日韩免费视频观看 | 久久久精品区 | 黄色网战在线观看 | 久久久99精品国产一区二区三区 | 成人在线免费播放 | 91chinese在线 | 在线观看h网站 | 日韩一级淫片 | 男女精品视频 | 中文无码精品一区二区三区 |