ACM/ICPC 之 Dinic算法(POJ2112)
Optimal Milking
//二分枚举最大距离的最小值+Floyd找到最短路+Dinic算法
//参考图论算法书,并对BFS构建层次网络算法进行改进
//Time:157Ms Memory:652K
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std; #define MAX 250
#define INF 0x3f3f3f3f int K, C, M;
int s, t;
int d[MAX][MAX]; //各点间最短距离
int res[MAX][MAX]; //残留网络
int lev[MAX]; void build_map(int limit)
{
memset(res,0,sizeof(res));
for (int i = K + 1; i <= K + C; i++)
res[s][i] = 1;
for (int i = 1; i <= K; i++)
res[i][t] = M;
for (int i = K + 1; i <= K + C; i++)
for (int j = 1; j <= K; j++)
if (d[i][j] <= limit) res[i][j] = 1;
} bool bfs() //BFS标记层次网络
{
memset(lev, -1, sizeof(lev));
queue<int> q;
q.push(s);
lev[s] = 0;
while (!q.empty()) { //构建层次网络
int cur = q.front();
q.pop();
for(int i = 1; i <= t; i++)
{
if(lev[i] == -1 && res[cur][i]) //未访问且正向有流量
{
q.push(i);
lev[i] = lev[cur] + 1;
}
}
}
return lev[t] != -1;
} int dfs(int v, int alpha) //DFS进行多次增广
{
if(v == t || alpha == 0) return alpha;
int src = alpha; //原可改进量
for(int i = 1; i <= t; i++)
{
if(res[v][i] && lev[i] == lev[v] + 1){ //识别下一层次
int tmp = dfs(i, min(alpha, res[v][i]));
res[v][i] -= tmp;
res[i][v] += tmp;
alpha -= tmp; //可改进量减少
}
}
return src - alpha; //总改进量
} int main()
{
//freopen("in.txt", "r", stdin); scanf("%d%d%d", &K,&C,&M);
s = 0; t = K + C + 1; //源点-汇点
for (int i = 1; i < t; i++)
for (int j = 1; j < t; j++)
{
scanf("%d", &d[i][j]);
if (d[i][j] == 0) d[i][j] = INF;
} for (int k = 1; k < t; k++)
for (int i = 1; i < t; i++)
{
if (d[i][k] != INF) {
for (int j = 1; j < t; j++)
d[i][j] = min(d[i][j], d[i][k] + d[k][j]);
}
} s = 0; t = K + C + 1; //源点 汇点
int l = 0, r = 9000;
while (l < r)
{
int ans = 0; //到达目的地的奶牛数量
int mid = (l + r) / 2;
build_map(mid);
while (bfs())
ans += dfs(0,INF); //第二参数指定该点可改进量
ans == C ? r = mid: l = mid+1;
}
printf("%d\n", r); return 0;
}
ACM/ICPC 之 Dinic算法(POJ2112)的更多相关文章
- ACM/ICPC 之 Dinic+枚举最小割点集(可做模板)(POJ1815)
最小割的好题,可用作模板. //Dinic+枚举字典序最小的最小割点集 //Time:1032Ms Memory:1492K #include<iostream> #include< ...
- ACM/ICPC 之 网络流入门-Ford Fulkerson与SAP算法(POJ1149-POJ1273)
第一题:按顾客访问猪圈的顺序依次构图(顾客为结点),汇点->第一个顾客->第二个顾客->...->汇点 //第一道网络流 //Ford-Fulkerson //Time:47M ...
- ACM - ICPC World Finals 2013 C Surely You Congest
原题下载:http://icpc.baylor.edu/download/worldfinals/problems/icpc2013.pdf 题目翻译: 试题来源 ACM/ICPC World Fin ...
- 2017 ACM/ICPC Asia Regional Qingdao Online
Apple Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total Submi ...
- 【转】lonekight@xmu·ACM/ICPC 回忆录
转自:http://hi.baidu.com/ordeder/item/2a342a7fe7cb9e336dc37c89 2009年09月06日 星期日 21:55 初识ACM最早听说ACM/ICPC ...
- 【转】ACM/ICPC生涯总结暨退役宣言—alpc55
转自:http://hi.baidu.com/accplaystation/item/ca4c2ec565fa0b7fced4f811 ACM/ICPC生涯总结暨退役宣言—alpc55 前言 早就该写 ...
- hduoj 4712 Hamming Distance 2013 ACM/ICPC Asia Regional Online —— Warmup
http://acm.hdu.edu.cn/showproblem.php?pid=4712 Hamming Distance Time Limit: 6000/3000 MS (Java/Other ...
- HDU 1532 (Dinic算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1532 题目大意: 就是由于下大雨的时候约翰的农场就会被雨水给淹没,无奈下约翰不得不修建水沟,而且是网络 ...
- 2015 ACM / ICPC 亚洲区域赛总结(长春站&北京站)
队名:Unlimited Code Works(无尽编码) 队员:Wu.Wang.Zhou 先说一下队伍:Wu是大三学长:Wang高中noip省一:我最渣,去年来大学开始学的a+b,参加今年区域赛之 ...
随机推荐
- Spring源码分析——BeanFactory体系之抽象类、类分析(二)
上一篇分析了BeanFactory体系的2个类,SimpleAliasRegistry和DefaultSingletonBeanRegistry——Spring源码分析——BeanFactory体系之 ...
- Spring Security(08)——intercept-url配置
http://elim.iteye.com/blog/2161056 Spring Security(08)--intercept-url配置 博客分类: spring Security Spring ...
- 记一次事件委托在 ios 下的兼容 bug
项目中碰到的兼容类 bug,记录一二. 页面上有几个同类型的控件,点击它们会触发一些事件,很显然,事件委托优于批量绑定.为了图方便,我将 click 事件绑定到了 document.body 上(绑定 ...
- .NET添加时间戳防止重放攻击
如过客户端在向服务端接口进行请求,如果请求信息进行了加密处理,被第三方截取到请求包,虽然第三方无法解密获取其中的数据,但是可以使用该请求包进行重复的请求操作.如果服务端不进行防重放攻击,就会参数服务器 ...
- Matlab2015入门学习02
1. 续行符 ... 当物理的一行之内写不下时, 在 物理行的结尾加上三个小黑点 >>跟在运算符之后,可以不留space空格 >>跟在数字之后,若不留白space,出错; 留一 ...
- 用Jedis连接Redis
jedis中的方法名,和Redis的命令几乎一样 1.jar包,作为测试只需要一个jar 2.代码 package com; import java.util.HashMap; import java ...
- 解决Java接口内部类的main()方法无法打印输出的问题
问题源自<Thinking in Java>关于内部类的章节,例子如下: public interface ClassInInterface{ void howdy(); public c ...
- 介绍编译的less的两种IDE工具
介绍编译的less的两种IDE工具 现在css预编译越来越普及了,著名的有less.sass.stylus等等等等.功能上基本上都是大同小异.这些个玩意儿主要表达的意思就是:"像编程一样的编 ...
- Java核心思想
回忆面向对象思想 面向对象,主页君也不敢对其多说什么,毕竟这是一个看似简单,但是其实蕴含很深层次理 论的东西,并不是看书就可以理解的,其实也是要在很多实际操作中学习,积累. ...
- A Quick Introduction to Linux Policy Routing
A Quick Introduction to Linux Policy Routing 29 May 2013 In this post, I’m going to introduce you to ...