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 ...
随机推荐
- Java 多线程 并发编程
一.多线程 1.操作系统有两个容易混淆的概念,进程和线程. 进程:一个计算机程序的运行实例,包含了需要执行的指令:有自己的独立地址空间,包含程序内容和数据:不同进程的地址空间是互相隔离的:进程拥有各种 ...
- MJRefresh简单处理
//下拉刷新 默认 self.bottomTableVeiw.header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{ [self he ...
- Leetcode: Remove K Digits
Given a non-negative integer num represented as a string, remove k digits from the number so that th ...
- 转:python类型转换、数值操作
类型转换 1 函数 描述 2 int(x [,base ]) 将x转换为一个整数 3 ...
- 2-sat按照最小字典序输出可行解(hdu1814)
Peaceful Commission Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...
- Java基础(41):Java中集合中需要注意的几个要点(关于Collection与Map)
同步性 Vector是同步的.这个类中的一些方法保证了Vector中的对象是线程安全的.而ArrayList则是异步的,因此ArrayList中的对象并 不是线程安全的.因为同步的要求会影响执 ...
- Missing artifact com.sun:tools:jar 1.5.0 终极解决方法
在使用m2eclipse插件时,在pom.xml中添加struts2-core.jar包后,需要依赖java运行时的tools.jar进行依赖.但是,此时eclipse无法读取tools包,出现如下错 ...
- 。。。Ajax的回调函数function(data)中,data的返回类型。。。
今天在做项目的过程中,突然发现了一个有趣的问题,那就是我在Java服务器端写程序,String result = "0";然后通过out.println(result),将resu ...
- android初体验——HelloWord
一.新建项目: 打开 eclipse ,选择File – New – Android Application Project 输入项目名称,程序名称,包名. 包名不能重复,它是项目的唯一标示,我理解为 ...
- opencv的一次性配置
最近做自然场景中的文字识别,想尝试些图像处理方法,感觉每一种方法都需要自己写很麻烦,自然就想到了强大的开源的跨平台计算机视觉库OpenCv.我用的是opencv2.4.9版本,VS用的是2010,他们 ...