Optimal Milking 分类: 图论 POJ 最短路 查找 2015-08-10 10:38 3人阅读 评论(0) 收藏
Optimal Milking
Time Limit: 2000MS Memory Limit: 30000K
Total Submissions: 13968 Accepted: 5044
Case Time Limit: 1000MS
Description
FJ has moved his K (1 <= K <= 30) milking machines out into the cow pastures among the C (1 <= C <= 200) cows. A set of paths of various lengths runs among the cows and the milking machines. The milking machine locations are named by ID numbers 1..K; the cow locations are named by ID numbers K+1..K+C.
Each milking point can “process” at most M (1 <= M <= 15) cows each day.
Write a program to find an assignment for each cow to some milking machine so that the distance the furthest-walking cow travels is minimized (and, of course, the milking machines are not overutilized). At least one legal assignment is possible for all input data sets. Cows can traverse several paths on the way to their milking machine.
Input
* Line 1: A single line with three space-separated integers: K, C, and M.
- Lines 2.. …: Each of these K+C lines of K+C space-separated integers describes the distances between pairs of various entities. The input forms a symmetric matrix. Line 2 tells the distances from milking machine 1 to each of the other entities; line 3 tells the distances from machine 2 to each of the other entities, and so on. Distances of entities directly connected by a path are positive integers no larger than 200. Entities not directly connected by a path have a distance of 0. The distance from an entity to itself (i.e., all numbers on the diagonal) is also given as 0. To keep the input lines of reasonable length, when K+C > 15, a row is broken into successive lines of 15 numbers and a potentially shorter line to finish up a row. Each new row begins on its own line.
Output
A single line with a single integer that is the minimum possible total distance for the furthest walking cow.
Sample Input
2 3 2
0 3 2 1 1
3 0 3 2 0
2 3 0 1 0
1 2 1 0 2
1 0 0 2 0
Sample Output
2
Source
USACO 2003 U S Open
题意:有c头奶牛和k个挤奶器,奶牛之间,挤奶器之间,奶牛与挤奶器之间都有一定的距离,问使c头奶牛都能挤奶的最大距离的最小值;
做法:距离问题,怎样知道任意点之间的距离,而且是最短距离,最短路算法floyd.
怎样求最大距离的最小值:由于数据量比较大,不能枚举,采用二分;
要确定二分的值是不是正确,就要用Dinic算法求出最大流看看是否>=c
#include <map>
#include <list>
#include <climits>
#include <cmath>
#include <queue>
#include <stack>
#include <string>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std;
#define eps 1e-9
#define LL long long
#define PI acos(-1.0)
#define INF 0x3f3f3f3f
#define CRR fclose(stdin)
#define CWW fclose(stdout)
#define RR freopen("input.txt","r",stdin)
#define WW freopen("output.txt","w",stdout)
const int Max = 300;
int Map[Max][Max];
int Dis[Max][Max];
bool vis[Max];
bool sign[Max][Max];
int K,c,m;
int n;
void BuildGraph(int MaxNum)//建立残留网络
{
memset(Map,0,sizeof(Map));
for(int i=K+1;i<=n;i++)
{
Map[0][i]=1;//将每一头奶牛与源点建立弧,对于每一头奶牛只去一个挤奶器
}
for(int i=1;i<=K;i++)
{
Map[i][n+1]=m;//将每个挤奶器与汇点建立弧,对于每个挤奶器最多接受m头奶牛
}
for(int i=K+1;i<=n;i++)
{
for(int j=1;j<=K;j++)
{
if(Dis[i][j]<=MaxNum)//限制条件
{
Map[i][j]=1;
}
}
}
}
bool BFS()//Dinic算法,建立层次网络;
{
memset(vis,false,sizeof(vis));
memset(sign,false,sizeof(sign));
int a;
queue<int>Q;
vis[0]=true;
Q.push(0);
while(!Q.empty())
{
a=Q.front();
Q.pop();
for(int i=0;i<=n+1;i++)
{
if(!vis[i]&&Map[a][i])
{
vis[i]=true;
sign[a][i]=true;
Q.push(i);
}
}
}
if(vis[n+1])//当标记不到汇点的时候说明残留网络中没有增广路,已经求得最大流,算法结束
{
return true;
}
return false;
}
int DFS(int s,int num)//
{
if(s==n+1)
{
return num;
}
int sum = num;
for(int i=0;i<=n+1;i++)
{
if(sign[s][i])
{
int ans=DFS(i,min(Map[s][i],num));//进行多次的增广,
Map[s][i]-=ans;
Map[i][s]+=ans;
num-=ans;
if(!num)//如果残余容量为零,则不必再增广
{
break;
}
}
}
return sum-num;
}
int main()
{
while(~scanf("%d %d %d",&K,&c,&m))
{
n=K+c;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
scanf("%d",&Dis[i][j]);
if(!Dis[i][j])
{
Dis[i][j]=INF;
}
}
}
for(int k=1;k<=n;k++)//通过floyd算法计算任意点之间的距离
{
for(int i=1;i<=n;i++)
{
if(Dis[i][k]!=INF)
{
for(int j=1;j<=n;j++)
{
Dis[i][j]=min(Dis[i][j],Dis[i][k]+Dis[k][j]);
}
}
}
}
int L=0,R=10000;
while(L<R)//通过不断的二分找到满足条件的最小值
{
int mid = (L+R)/2;
int sum = 0;
BuildGraph(mid);
while(BFS())//Dinic算法,直到不能增广时结束
{
sum+=DFS(0,INF);//计算有多少的奶牛挤奶
}
if(sum>=c)
{
R=mid;
}
else
{
L=mid+1;
}
}
printf("%d\n",R);//R就是所要求的最大距离的最小值
}
return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
Optimal Milking 分类: 图论 POJ 最短路 查找 2015-08-10 10:38 3人阅读 评论(0) 收藏的更多相关文章
- Pots 分类: 搜索 POJ 2015-08-09 18:38 3人阅读 评论(0) 收藏
Pots Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 11885 Accepted: 5025 Special Judge D ...
- HDU 1532 Drainage Ditches 分类: Brush Mode 2014-07-31 10:38 82人阅读 评论(0) 收藏
Drainage Ditches Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU 1272 小希的迷宫(并查集) 分类: 并查集 2015-07-07 23:38 2人阅读 评论(0) 收藏
Description 上次Gardon的迷宫城堡小希玩了很久(见Problem B),现在她也想设计一个迷宫让Gardon来走.但是她设计迷宫的思路不一样,首先她认为所有的通道都应该是双向连通的,就 ...
- Codeforces 343D Water Tree 分类: Brush Mode 2014-10-05 14:38 98人阅读 评论(0) 收藏
Mad scientist Mike has constructed a rooted tree, which consists of n vertices. Each vertex is a res ...
- HDu 1001 Sum Problem 分类: ACM 2015-06-19 23:38 12人阅读 评论(0) 收藏
Sum Problem Time Limit: 1000/500 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...
- Python调用C可执行程序(subprocess) 分类: python 服务器搭建 C/C++ shell 2015-04-13 21:03 87人阅读 评论(0) 收藏
从Python 2.4开始,Python引入subprocess模块来管理子进程,以取代一些旧模块的方法:如 os.system.os.spawn.os.popen.popen2.commands. ...
- /var/log目录下的20个Linux日志文件功能详解 分类: 服务器搭建 linux内核 Raspberry Pi 2015-03-27 19:15 80人阅读 评论(0) 收藏
如果愿意在Linux环境方面花费些时间,首先就应该知道日志文件的所在位置以及它们包含的内容.在系统运行正常的情况下学习了解这些不同的日志文件有助于你在遇到紧急情况时从容找出问题并加以解决. 以下介绍的 ...
- shell入门之流程控制语句 分类: 学习笔记 linux ubuntu 2015-07-10 16:38 89人阅读 评论(0) 收藏
1.case 脚本: #!/bin/bash #a test about case case $1 in "lenve") echo "input lenve" ...
- IOS第三方数据库--FMDB 分类: ios技术 2015-03-01 09:38 57人阅读 评论(0) 收藏
iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepers ...
随机推荐
- Velocity(3)——字面值和转义
货币符号: $是美元的符号,在文本中出现的"$2.5"这样的字符串,是不会被Velocity解释为一个变量或者一个属性的,因为2.5或者2或者5都不是一个VTL标识符. 转义: 假 ...
- Leetcode: Convert a Number to Hexadecimal
Given an integer, write an algorithm to convert it to hexadecimal. For negative integer, two's compl ...
- javascript 异常处理和事件处理
异常捕获 1.异常:当javascript引擎执行JS代码时,发生了错误,导致程序停止运行. 2.异常抛出:当异常产生,并且将这个异常生成一个错误信息 3.异常捕获: try{发生异常的代码块:}ca ...
- JDBC工作模块
jdbc-->java数据库连接 的简称 JDBC工作模块 加载jdbc驱动 与数据库连接 发送sql语句,得到返回结果 处理返回结果 释放资源
- fork子进程之间传输信息的方法(包含子进程与子进程之间区分的问题的解决)
今天看到一道题,要求是父进程fork出两个子进程,子进程1需要给子进程2发送一个数据,然后子进程2再将这个数据发送给父进程 具体思想如下. 父进程fork出来的子进程的pid,只有父进程保存下来了, ...
- JS 实现中英文翻译
缺点就是还是会闪出中文,但是效果还行. var langPackage = { "主题":"Title", "下一页":"Next ...
- JAVA实现File类中的遍历操作并输出内容
package shb.java.testIo; import java.io.BufferedReader; import java.io.BufferedWriter; import java.i ...
- drds 广播表的创建以及使用
创建表 , 关键词 : BROADCAST CREATE TABLE `financial_product_yjw` ( `ID` int(10) unsigned NOT NULL AUTO_INC ...
- 高手看了,感觉惨不忍睹——关于“【ACM】杭电ACM题一直WA求高手看看代码”
按 被中科大软件学院二年级研究生 HCOONa 骂为“误人子弟”之后(见:<中科大的那位,敢更不要脸点么?> ),继续“误人子弟”. 问题: 题目:(感谢 王爱学志 网友对题目给出的翻译) ...
- Android_adb详解
adb定义:adb(android debug bridge)是android系统中的一种命令行工具,通过它可以和android设备或模拟器通信. adb工具位置: <path-to-sdk&g ...