Uvaoj 11248 Frequency Hopping(Dinic求最小割)

題意:1到n節點(節點之間有一定的容量),需要流過C的流量,問是否可以?如果可以輸出possible, 否則如果可以擴大任意一條邊的容量
可以達到目的,那么輸出possible option:接著輸出每一條可以達到目的的邊(按升序),再否則輸出not possible
思路:先求一次最大流,如果流量至少為C,則直接輸出possible,否則需要修改的弧一定在最小割里!
接著吧這些弧(最小割里的)的容量設為無窮大,然后在求最大流,看最大流的流量能否滿足是C即可,如果滿足了,那就把這一條邊記錄下來

分析:最大流的程序沒有必要完全的執行完畢,知道當前的流量>=C那么就可以中止最大流的程序!
還有就是第一次的最大流程序如果沒有找到>=C的最大流,那么此時的流量留著,下一次在最小割里擴容的時候,總是接著第一次Dinic的流量
繼續尋找....

  1 #include<iostream>
  2 #include<cstring>
  3 #include<cstdio>
  4 #include<algorithm>
  5 #include<vector>
  6 #include<queue>
  7 #define N 105
  8 #define INF 2000000005
  9 using namespace std;
 10 
 11 struct EDGE{
 12     int u, v, nt, cap;
 13     bool flag;
 14     bool vis;
 15     EDGE(){}
 16     EDGE(int u, int v, int nt, int cap, bool flag):u(u), v(v), nt(nt), cap(cap), flag(flag){}
 17 };
 18 
 19 struct node{
 20     int x, y;
 21     node(){}
 22     node(int x, int y) : x(x), y(y){}
 23 };
 24 
 25 int pos[10005];
 26 
 27 node ans[10005];
 28 int preCost[20005];
 29 int vis[20005];
 30 int p[20005];
 31 int pcnt;
 32 int cnt;
 33 
 34 vector<EDGE>g;
 35 int first[N];
 36 
 37 int d[N];
 38 int n, e, c;
 39 
 40 void addEdge(int u, int v, int c){
 41     g.push_back(EDGE(u, v, first[u], c, true));
 42     first[u] = g.size() - 1;
 43     g.push_back(EDGE(v, u, first[v], 0, false));
 44     first[v] = g.size() - 1;
 45 }
 46 
 47 bool bfs(){
 48     memset(d, 0, sizeof(d));
 49     d[1] = 1;
 50     queue<int>q;
 51     q.push(1);
 52     while(!q.empty()){
 53         int u = q.front();
 54         q.pop();
 55         for(int i = first[u]; ~i; i = g[i].nt){
 56             int v = g[i].v;
 57             if(!d[v] && g[i].cap > 0){
 58                 d[v] = d[u] + 1;
 59                 q.push(v);
 60             }
 61         }
 62     }
 63     if(d[n] == 0) return false;
 64     return true;
 65 }
 66 
 67 bool cmp(node a, node b){
 68     if(a.x == b.x)
 69          return a.y < b.y;
 70     return a.x < b.x;
 71 }
 72 
 73 int leave;
 74 
 75 int dfs(int u, int totf){
 76     int flow = 0;
 77     if(u ==n || totf==0) return totf;
 78     for(int i = first[u]; ~i; i = g[i].nt){
 79         int v = g[i].v;
 80         if(d[v] == d[u] + 1 && g[i].cap > 0){
 81             int ff  = dfs(v, min(totf-flow, g[i].cap));
 82             if(ff > 0){
 83                 if(!vis[i]){
 84                     p[pcnt++]=i;
 85                     preCost[i] = g[i].cap;
 86                     vis[i] = 1;
 87                 }
 88                 g[i].cap -= ff;
 89 
 90                 if(!vis[i^1]){
 91                     p[pcnt++]=i^1;
 92                     preCost[i^1] = g[i^1].cap;
 93                     vis[i^1] = 1;
 94                 }
 95                 g[i^1].cap += ff;
 96                 flow += ff;
 97                 
 98                 if(flow >= leave){
 99                     flow = leave;
100                     return flow;
101                 }
102 
103                 if(totf == flow) break;
104             }
105             else d[v] = -1;
106         }
107     }
108     return flow;
109 }
110 
111 bool Dinic(){
112     leave = c;
113     while(bfs()){
114         leave -= dfs(1, INF);
115         if(leave == 0) break;
116     }
117     if(leave == 0) return true;
118     return false;
119 }
120  
121 
122 
123 int main(){
124     int cas = 0;
125     while(scanf("%d%d%d", &n, &e, &c)){
126         if(!n) break;
127         memset(first, -1, sizeof(first));
128         g.clear();
129         cnt = 0;
130         while(e--){
131             int x, y, z;
132             scanf("%d%d%d", &x, &y, &z);
133             addEdge(x, y, z);
134         }
135         printf("Case %d: ", ++cas);//這一塊差點沒有把我氣死...居然有一個空格,沒有看清楚啊...一直PE.
136      
137         if(n==1){
138             printf("possible\n");
139             continue;
140         }
141 
142         if(Dinic())  printf("possible\n");
143         else{
144             int len = g.size();
145             for(int i=0; i<len; ++i)
146                 if(g[i].cap == 0 && g[i].flag)
147                     pos[cnt++] = i;//得到最小割
148             int cc = leave;//第一次Dinic之后,還剩下多少的流量需要流過
149             int ret = 0;
150             for(int i=0; i<cnt; ++i){
151                 c = cc;//新的需要流過的流量
152                 pcnt = 0;
153                 g[pos[i]].cap = INF;
154                 memset(vis, 0, sizeof(vis));
155                 if(Dinic())//如果增廣成功,那么這條最小割滿足
156                        ans[ret++] = node(g[pos[i]].u, g[pos[i]].v);
157                 for(int j=0; j<pcnt; ++j)
158                     g[p[j]].cap = preCost[p[j]];//將Dinic中所經過的邊的值恢復成第一次Dinic之后的值!
159                 g[pos[i]].cap = 0;
160             }
161             if( ret > 0 ){
162                 sort(ans, ans+ret, cmp);
163                 printf("possible option:(%d,%d)", ans[0].x, ans[0].y);
164                 for(int i=1; i<ret; ++i)
165                     printf(",(%d,%d)", ans[i].x, ans[i].y);
166                 printf("\n");
167             }
168             else printf("not possible\n");
169         }
170     }    
171     return 0;
172 }
View Code

?

轉載于:https://www.cnblogs.com/hujunzheng/p/4014923.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531606.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531606.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531606.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

隨機數歸并排序c語言,用C語言實現歸并排序

#include#include#include#include#define random(i) (rand()%i)#define N 12#define INFINITY 99999999//要排序的數存放在a數組匯總&#xff0c;p,q,r是數組下標void Merge(int *a,int p,int q,int r){int n1q-p1;int n2r-q;int *L(int *)malloc(sizeof(int)*n1);int *R(int …

UVAoj 11324 - The Largest Clique(tarjan + dp)

題意&#xff1a;給定一個有向圖&#xff0c;尋找一個點數最大集合&#xff0c;使得這個集合中的任意兩個點 u,v, 都有u->v 或者 v->u 或者u<>v 思路&#xff1a;首先將強連通分量通過tarjan算法求出來&#xff0c;然后進行縮點&#xff0c;也就是每一個縮點 所組成…

android開發藍牙自動連接電腦上,Android藍牙開發之自動連接設備

自動連接使用的是SharedPreferences這個來解決。private void Automaticconnection() {SharedPreferences sp getSharedPreferences("Dizhi", MODE_PRIVATE);String address sp.getString("address", "");if (!address.equals("")) …

hdu 2014鞍山賽區 5073 Galaxy

題意&#xff1a;就是給你 n 個數&#xff0c;代表n個星球的位置&#xff0c;每一個星球的重量都為 1 &#xff01; 開始的時候每一個星球都繞著質心轉動&#xff0c;那么質心的位置就是所有的星球的位置之和 / 星球的個數 現在讓你移動 k 個星球到任意位置&#xff08;多個星球…

android onitemclicklistener 參數,android – 對listview中的項使用setOnItemClickListener

大家好,有一個應用程序,可以在SD卡上保存音頻.我創建了一個listview,它從sdcard中檢索文件名.我正在嘗試設置一個監聽器,所以當單擊文件名時,我可以啟動另一個播放該文件的意圖.當我嘗試設置監聽器并傳入一個新的OnItemClickListener()時,eclipse是紅色的下劃線.我知道我必須實…

DRF之請求與響應

目錄 一、模塊與包回顧 二、反序列化校驗源碼分析(了解) 三、斷言 四、drf之請求 【1】源碼分析 【2】配置視圖類能處理的編碼格式 五、drf之響應 【1】源碼 【2】響應編碼格式 一、模塊與包回顧 模塊與包 什么是模塊&#xff1f; 一個py文件&#xff0c;被別的py文件…

android 常用注解,Android 開發小工具之:注解 Annotation

Android Support 包之一的 support-annotations是通過靜態編譯檢測來提高代碼質量的一個注解工具。里面包含了 Android 開發中常用的代碼檢測注解&#xff0c;幫助開發者提高代碼質量。通過 SDK Manager下載 Android Support Repository 后&#xff0c;在 Gradle 中通過如下聲明…

codeforces B. Friends and Presents(二分+容斥)

題意&#xff1a;從1....v這些數中找到c1個數不能被x整除&#xff0c;c2個數不能被y整除&#xff01; 并且這c1個數和這c2個數沒有相同的&#xff01;給定c1, c2, x, y&#xff0c; 求最小的v的值&#xff01; 思路&#xff1a; 二分容斥&#xff0c;二分找到v的值&#xff0c;…

android音量鍵廣播,音量控制鍵控制的音頻流(setVolumeControlStream)描述

音量控制鍵控制的音頻流(setVolumeControlStream)描述2021-01-03 16:18Android教程網 Android當開發多媒體應用或者游戲應用的時候&#xff0c;需要使用音量控制鍵來設置程序的音量大小,在Android系統中有多種音頻流,感興趣的朋友可以了解下當開發多媒體應用或者游戲應用的時候…

eclipse的使用

eclipse如何打開一個已存在的工程&#xff01;先給eclipse創建一個workspace,這個workspace就是一個文件夾用來管理eclipse項目的&#xff0c;或者修改eclipse的workspace,選擇菜單file->switch workspace->other,選擇一個已經存在的workspace。將已經存在的項目導入到wo…

Android延伸布局到狀態欄,Android 狀態欄透明

前言&#xff1a;最近項目大量用到狀態欄透明&#xff0c;網上也出現很多庫可以直接拿來用&#xff0c;個人認為沒有必要那么重引用到一個庫(有木有同學和我有一樣的想法)&#xff0c;所以研究了一番&#xff0c;在此做個記錄加強記憶也便后期查閱&#xff0c;如果無意中有幸能…

glassfish服務器默認的網頁所在的位置

http://localhost:8080/ 默認打開的網頁所在的位置 E:/glassfish-4.1/glassfish/domains/domain1/docroot/index.html 轉載于:https://www.cnblogs.com/hujunzheng/p/4052920.html

華為HarmonyOS 鴻蒙,華為鴻蒙HarmonyOS2.0手機開發者Beta版正式發布

據悉&#xff0c;本次手機開發者Beta測試支持以下中國境內主制式手機及平板電腦。手機&#xff1a;全網通(5G雙卡)P40 、 全網通版P40 Pro、Mate30、Mate30(5G) 、Mate30 Pro、Mate30 Pro(5G)&#xff0c;型號清單為ANA-AN00、ELS-AN00、TAS-AL00、TAS-AN00、LIO-AL00、LIO-AN0…

http協議客戶端向服務器端請求時一般需要發送的內容

out.println("GET /shopping/index.html HTTP/1.1");//請求行 包括請求方式&#xff0c;文件路徑&#xff0c; http協議版本&#xff08;必寫&#xff09;請求頭.... out.println("Aceept: */*");//客戶端能夠處理的文件類型&#xff08;不是必須&#xff…

android oneshot自動播放bug,移動端常見bug匯總001

前言本文是摘錄整理了移動端常見的一些bug以及解決方案&#xff0c;第一篇&#xff0c;后面還會有持續的文章更新整理。點擊樣式閃動Q: 當你點擊一個鏈接或者通過Javascript定義的可點擊元素的時候&#xff0c;它就會出現一個半透明的灰色背景。A:根本原因是-webkit-tap-highli…

int.class 與 Integer.class

TYPE 表示的引用類型所對應的基本類型的Class對象&#xff01; 轉載于:https://www.cnblogs.com/hujunzheng/p/4055471.html

android uber啟動動畫,模仿Uber的啟動畫面(上)

啟動畫面(Splash Screen)——不但給開發者們提供了一個盡情發揮、創建有趣動畫的機會&#xff0c;也填補了App啟動時從終端慢吞吞地下載數據的時間。啟動畫面(動態的)對于App至關重要&#xff1a;它可以讓用戶不失興趣地耐心等待應用完成加載。盡管現在的啟動畫面多種多樣&…

java中產生對象的兩種方式

/** 普通new對象的過程&#xff01;*/Person pp new Person();System.out.println(pp);/** 利用代用參數的構造器產生對象實例&#xff01;* 首先獲得相應帶參數的構造器&#xff0c;然后利用構造器產生對象實例&#xff01;*/pclass Class.forName("get_class_method.P…

智慧屏用鴻蒙的生態,緊隨鴻蒙OS手機版 ,智慧屏為什么對鴻蒙生態這么重要?...

原標題&#xff1a;緊隨鴻蒙OS手機版 &#xff0c;智慧屏為什么對鴻蒙生態這么重要&#xff1f;12 月 21 日&#xff0c;華為正式發布了兩款智慧屏新品&#xff0c;智慧屏 S 系列和車載智慧屏&#xff0c;前者是智慧屏的新系列&#xff0c;后者則是新開辟的車機產品線。沒有意外…

java中反射機制通過字節碼文件對象獲取字段和函數的方法

pclass Class.forName("get_class_method.Person");//Field ageField pclass.getField("age");//因為age成員變量是私有的&#xff0c;所以會產生NoSuchFieldException異常Field ageField pclass.getDeclaredField("age");//獲得該對象反映此…