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)的更多相关文章

  1. ACM/ICPC 之 Dinic+枚举最小割点集(可做模板)(POJ1815)

    最小割的好题,可用作模板. //Dinic+枚举字典序最小的最小割点集 //Time:1032Ms Memory:1492K #include<iostream> #include< ...

  2. ACM/ICPC 之 网络流入门-Ford Fulkerson与SAP算法(POJ1149-POJ1273)

    第一题:按顾客访问猪圈的顺序依次构图(顾客为结点),汇点->第一个顾客->第二个顾客->...->汇点 //第一道网络流 //Ford-Fulkerson //Time:47M ...

  3. ACM - ICPC World Finals 2013 C Surely You Congest

    原题下载:http://icpc.baylor.edu/download/worldfinals/problems/icpc2013.pdf 题目翻译: 试题来源 ACM/ICPC World Fin ...

  4. 2017 ACM/ICPC Asia Regional Qingdao Online

    Apple Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submi ...

  5. 【转】lonekight@xmu·ACM/ICPC 回忆录

    转自:http://hi.baidu.com/ordeder/item/2a342a7fe7cb9e336dc37c89 2009年09月06日 星期日 21:55 初识ACM最早听说ACM/ICPC ...

  6. 【转】ACM/ICPC生涯总结暨退役宣言—alpc55

    转自:http://hi.baidu.com/accplaystation/item/ca4c2ec565fa0b7fced4f811 ACM/ICPC生涯总结暨退役宣言—alpc55 前言 早就该写 ...

  7. 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 ...

  8. HDU 1532 (Dinic算法)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1532 题目大意: 就是由于下大雨的时候约翰的农场就会被雨水给淹没,无奈下约翰不得不修建水沟,而且是网络 ...

  9. 2015 ACM / ICPC 亚洲区域赛总结(长春站&北京站)

    队名:Unlimited Code Works(无尽编码)  队员:Wu.Wang.Zhou 先说一下队伍:Wu是大三学长:Wang高中noip省一:我最渣,去年来大学开始学的a+b,参加今年区域赛之 ...

随机推荐

  1. Qt——消息对话框的设计

    1.消息对话框是什么 消息对话框(MessageBox)提供了一个模态对话框,用来通知用户某些信息,或者用来询问用户一个问题并获得一个答复. 先看下面2张图—— 第一张图是网易云音乐的界面截图,在删除 ...

  2. p2p网贷平台设计简析

    以我之前主持开发的一个商业产品:p2p网贷为例进行分析.整个的概况,可以参见:www.huixinp2p.com(目的只会技术交流) 界面可以直接参考前期博客:http://www.cnblogs.c ...

  3. 记一次事件委托在 ios 下的兼容 bug

    项目中碰到的兼容类 bug,记录一二. 页面上有几个同类型的控件,点击它们会触发一些事件,很显然,事件委托优于批量绑定.为了图方便,我将 click 事件绑定到了 document.body 上(绑定 ...

  4. qq菜单的折叠与展示

    敲出每个小例子是一种进步 html结构: <body> <ul id="list"> <li class="lis"> &l ...

  5. c++/java/python priority_que实现最大堆和最小堆

    #include<iostream>#include<vector>#include<math.h>#include<string>#include&l ...

  6. 关于GIL

    1同一时刻只有一个线程通过一个线程到解释器运行 2在多核上会有些不一样 不仅仅会降低python的效率 并且还会影响到整个机器系统的效率 python的gil是每100条cpu指令开始check 如果 ...

  7. JavaScript零基础学习系列三

    函数 函数:为了完成某个功能而定义的代码的集体.函数是数据类型,只读的对象:函数也是对象:代码的重用.(JavaScript中) 定义语法:function 函数名(形式参数1,形式参数2--){ / ...

  8. extracting fasta records from a multi-fasta file based on a list using awk

    for i in $(cat gene_list) do awk -v RS=">" '($1==a){print ">"$0}' a=$i inp ...

  9. MYSQL之基本操作

    数据库操作 一.查看所有的数据库 show databases; 二.创建数据库 create database userinfo; 说明: 创建了一个名为userinfo的数据库 三.使用数据库 u ...

  10. Redis模式匹配删除key

    Redis keys命令支持模式匹配,但是del命令不支持模式匹配,有时候需要根据一定的模式来模糊删除key,这时只能结合shell命令来完成了. 具体命令是: redis-cli KEYS &quo ...