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,参加今年区域赛之 ...
随机推荐
- Asp.Net MVC3 简单入门详解过滤器Filter(转)
前言 在开发大项目的时候总会有相关的AOP面向切面编程的组件,而MVC(特指:Asp.Net MVC,以下皆同)项目中不想让MVC开发人员去关心和写类似身份验证,日志,异常,行为截取等这部分重复的代码 ...
- NB實體連線到公司的網路,無法上網解決方案,需設 proxy。
未使用 VPN Cisco Anyconnect 已連線到公司的網路: google-chrome-stable --proxy-server="proxy.XXXcomm.com:3128 ...
- 安卓 service
public class MyService extends Service { public MyService() { } @Override public IBinder onBind(Inte ...
- 使用CocoaPods开发并打包静态库
Cocoapods作为OS X和iOS开发平台的类库管理工具,已经非常完善和强大.通常我们用pod来管理第三方开源类库,但我们也极有可能会开发一个用pod管理依赖关系的静态类库给其他人使用,而又不愿意 ...
- nginx文件管理
管理文件下载nginx 可以自己实现,无需写代码即可: 修改配置文件: location /doc { autoindex on; autoindex_exact_size on; autoindex ...
- 【Alpha】阶段汇总
[项目文档&API文档] PhyLab2.0需求与功能分析改进文档(NABCD) PhyLab2.0设计分析阶段任务大纲(α) 团队个人贡献分分配规则 功能规格说明书 [Phylab2.0]A ...
- 【CityHunter】通过Unity3D来制作游戏中AR部分的内容
嗯,最近再考虑,CityHunter中,玩家攻略藏宝图时,为了增加可玩性,应该增强在AR部分的游戏性.最近特别火的游戏<Pokemon Go>在打开摄像头以后,可以看到小精灵,实际上,如果 ...
- Character类
Character类 用来判断大小写 方法: public static boolean isUpperCase(char ch):判断是否大写 public static boolean isLow ...
- 漫谈JVM
背景介绍 JVM已经是Java开发的必备技能了,JVM相当于Java的操作系统. JVM,java virtual machine, 即Java虚拟机,是运行java class文件的程序. Java ...
- e-chart 本地加载中国地图
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...