HDOJ3549-Flow Problem(最大流)

Problem Description

Network flow is a well-known difficult problem for ACMers. Given a graph, your task is to find out the maximum flow for the weighted directed graph.

Input

The first line of input contains an integer T, denoting the number of test cases.For each test case, the first line contains two integers N and M, denoting the number of vertexes and edges in the graph. (2 <= N <= 15, 0 <= M <= 1000)Next M lines, each line contains three integers X, Y and C, there is an edge from X to Y and the capacity of it is C. (1 <= X, Y <= N, 1 <= C <= 1000)

Output

For each test cases, you should output the maximum flow from source 1 to sink N.

Sample Input

2
3 2
1 2 1
2 3 1
3 3
1 2 1
2 3 1
1 3 1

Sample Output

Case 1: 1
Case 2: 2

Code:

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3
 4 #define CLR(x , v)      memset(x , v , sizeof(x))
 5
 6 static const int OO = 0x3fffffff;
 7
 8 static const int MAXN = 1e3 + 10;
 9
10 int n , m;
11 int cap[MAXN][MAXN];
12 int flow[MAXN][MAXN];
13 int add[MAXN];
14 queue<int> q;
15 int pre[MAXN];
16 int main()
17 {
18     int t;
19     scanf("%d" , &t);
20     for(int c = 1 ; c <= t ; ++c)
21     {
22         int ans = 0;
23         CLR(cap , 0);
24         CLR(flow , 0);
25         CLR(pre , 0);
26         while(!q.empty())
27             q.pop();
28         scanf("%d%d" , &n , &m);
29         for(int i = 1 ; i <= m ; ++i)
30         {
31             int a , b , c;
32             scanf("%d%d%d" , &a , &b , &c);
33             cap[a][b] += c;
34         }
35
36         for(;;)
37         {
38             CLR(add , 0);
39             add[1] = OO;
40             q.push(1);
41             while(!q.empty())
42             {
43                 int u = q.front();
44                 q.pop();
45                 for(int i = 1 ; i <= n ; ++i)
46                 {
47                     if(!add[i] && cap[u][i] > flow[u][i])
48                     {
49                         pre[i] = u;
50                         q.push(i);
51                         add[i] = min(add[u] , cap[u][i] - flow[u][i]);
52                     }
53                 }
54             }
55
56             if(!add[n])
57                 break;
58
59             for(int i = n ; i != 1 ; i = pre[i])
60             {
61                 flow[pre[i]][i] += add[n];
62                 flow[i][pre[i]] -= add[n];//反向弧
63             }
64
65             ans += add[n];
66         }
67
68         printf("Case %d: %d\n" , c , ans);
69     }
70 }

时间: 2024-10-13 04:17:52

HDOJ3549-Flow Problem(最大流)的相关文章

HDU 3549 Flow Problem ( 最大流 -EK 算法)

C++,G++的读取速度差距也太大了 Flow Problem 题意:n,m表示n个点m条有向带权边 问:从1-n最大流多少 裸最大流,拿来练手,挺不错的 #include <iostream> #include <cstdlib> #include <cstdio> #include <cstring> #include <queue> #include <algorithm> const int N = 210; #define

HDU 3549 Flow Problem (最大流)

链接:click here 题意:Network flow is a well-known difficult problem for ACMers. Given a graph, your task is to find out the maximum flow for the weighted directed graph. 翻译:网络流量是一个众所周知的难题ACMers.给定一个图,你的任务是找出加权有向图的最大流. 输出格式: Case 1: 1 Case 2: 2 思路:跟hdu153

hdu - 3549 Flow Problem (最大流模板题)

http://acm.hdu.edu.cn/showproblem.php?pid=3549 Ford-Fulkerson算法. #include <iostream> #include <cstdio> #include <cmath> #include <vector> #include <cstring> #include <string> #include <algorithm> #include <stri

HDU3549:Flow Problem(最大流入门EK)

#include <stdio.h> #include <string.h> #include <stdlib.h> #include <queue> #include <math.h> #define inf 0x3f3f3f3f using namespace std; int map[50][50],v[50],pre[1000]; int n,m; int bfs(int s,int t) { memset(v,0,sizeof(v));

hdu3549 Flow Problem(裸最大流)

Flow Problem Time Limit:5000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Description Network flow is a well-known difficult problem for ACMers. Given a graph, your task is to find out the maximum flow for the weighted d

HDU 3549 Flow Problem (最大流ISAP)

Flow Problem Time Limit: 5000/5000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submission(s): 8199    Accepted Submission(s): 3814 Problem Description Network flow is a well-known difficult problem for ACMers. Given a graph, yo

hdoj 3549 Flow Problem 【最大流】

题目:hdoj 3549 Flow Problem 题意:给出一个图,让你求最大流. 分析:这个题目用dinci写的,因为点比较少,而dinci复杂度O(m*n^2),但是还是跑了160ms,不知道15的神牛怎么写的. dinci的写法要注意的地方就是存图的时候要考虑怎么存,因为要更新网络残量,即反向的流量,所以这里要注意一下. 思想就不讲了,很多地方有讲. 代码: #include <cstdio> #include <cstring> #include <iostream

hdu 3549 Flow Problem(最大流模板题)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3549 Problem Description Network flow is a well-known difficult problem for ACMers. Given a graph, your task is to find out the maximum flow for the weighted directed graph. Input The first line of input

hdu 3549 Flow Problem (网络最大流)

Flow Problem Time Limit: 5000/5000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submission(s): 6674    Accepted Submission(s): 3112 Problem Description Network flow is a well-known difficult problem for ACMers. Given a graph, yo

HDU 3549 Flow Problem(最大流)

Flow Problem Time Limit: 5000/5000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) Total Submission(s): 12625    Accepted Submission(s): 6004 Problem Description Network flow is a well-known difficult problem for ACMers. Given a graph,