poj2391 Ombrophobic Bovines 题解
http://poj.org/problem?id=2391
floyd+网络流+二分
题意:有一个有向图,里面每个点有ai头牛,快下雨了牛要躲进雨棚里,每个点有bi个雨棚,每个雨棚只能躲1头牛。牛可以通过点之间的边移动来躲到其他的点的雨棚,路很宽一次可以走无数头牛,路的权是牛走过这条路要的时间。求最短需要多少时间所有牛都躲到雨棚下。
题解:
先floyd求出每个点到每个点的最短时间!然后二分答案,也就是二分牛躲完的时间,然后大于这个时间的路都封了,建个碉图,每个点分成两个点A和B,起点连接到所有的A,流量为牛数,所有的点B连接到终点,流量为棚数,一些A连接到一些B,流量为无限,代表牛的移动。二分+网络流,啪啪啪就过了。这是我做的第一个二分+网络流的题,好激动口牙!
#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
const long long inf=0x7fffffffffffLL;
const int MAXN=;
long long a[MAXN][MAXN];
long long b[MAXN][MAXN];
long long d[MAXN][MAXN];
int m,n;
ll c[MAXN][MAXN];
ll D[MAXN],h[MAXN],g[MAXN];
bool found;
ll augc,flow;
int st,ed,N;
ll sum; void floyd()
{
int i,j,k;
memcpy(d,b,sizeof(b));
for(k=;k<=n;k++)
for(i=;i<=n;i++)
for(j=;j<=n;j++)
if(d[i][k]+d[k][j]<d[i][j])
d[i][j]=d[i][k]+d[k][j];
} void aug(const int m)
{
int i,augco=augc,mini,minh=N-;
if (m==ed)//如果当前结点为汇点
{
found=true;
flow+=augc; //增加流量
return;
}
for (i=D[m]; i<=N; i++)//寻找容许边
if (c[m][i]> && h[i]+==h[m])//如果残留容量大于0,如果是容许边
{
if (c[m][i]<augc) augc=c[m][i];//如果容许边流量小于当前增广路流量 则更新增广路流量
D[m]=i; //把i定为当前弧
aug(i); //递归
if (h[]>=N) return; //GAP 如果源点距离标号大于n 则停止算法
if (found) break; //如果找到汇点 则退出寻找
augc=augco;//没找到就还原当前的流
}
if (!found) //重标号
{
for (i=; i<=N; i++) //找那个标号,这里不能用d[m]开始,不然会蛋疼
if (c[m][i]> && h[i]<minh)
{
minh=h[i];
mini=i;
}
g[h[m]]--; //GAP 距离为
if (g[h[m]]==) h[]=N; //GAP
h[m]=minh+;
D[m]=mini;
g[h[m]]++; //GAP
}
else
{//修改残量
c[m][i]-=augc;
c[i][m]+=augc;
}
} bool farm(ll time)
{
int i,j;
//cout<<"farm"<<time<<endl;
memcpy(c, a, sizeof(a));
for(i=;i<=n;i++)
for(j=;j<=n;j++)
if(d[i][j]<=time) c[i+][j++n]=inf;
else c[i+][j++n]=;
N=ed;
// for(i=1;i<=N;i++)
// {
// for(j=1;j<=N;j++)
// cout<<c[i][j]<<' ';
// cout<<endl;
// }
memset(h,,sizeof(h));
memset(g,,sizeof(g));
g[]=N;
flow=;
for(i=; i<=N; i++)
D[i]=;//当前弧初始化
while(h[]<N)
{
augc=inf;//初始化增广路容量为正无穷大
found=false;
aug();//从源点开始找
}
if(flow==sum) return true;
else return false;
} int main()
{
int i,j,k;
ll x,y,z;
while(scanf("%d%d",&n,&m)!=EOF)
{
sum=;
memset(a,,sizeof(a));
st=;ed=n+n+;
for(i=;i<=n+;i++)
{
scanf("%lld%lld",&x,&y);
sum+=x;
a[][i]+=x;
a[i+n][ed]+=y;
}
for(i=;i<=n;i++)
for(j=;j<=n;j++)
b[i][j]=inf;
for(i=;i<=n;i++)
b[i][i]=;
for(i=;i<=m;i++)
{
scanf("%lld%lld%lld",&x,&y,&z);
b[x][y]=min(b[x][y],z);
b[y][x]=b[x][y];
}
floyd();
ll l=inf,r=-;
for(i=;i<=n;i++)
for(j=;j<=n;j++)
{
l=min(l,d[i][j]);
r=max(r,d[i][j]);
}
r=min(inf-,r);
if (!farm(r))
{
printf("-1\n");
continue;
}
ll mid=(l+r)/,pl=-,pr=-;
while(l!=pl || r!=pr)
{
pl=l;pr=r;
if(farm(mid)) r=mid;
else l=mid;
mid=(l+r)/;
//cout<<l<<','<<r<<','<<mid<<endl;
}
printf("%lld\n",r);
}
return ;
}
poj2391 Ombrophobic Bovines 题解的更多相关文章
- poj2391 Ombrophobic Bovines 拆点+二分法+最大流
/** 题目:poj2391 Ombrophobic Bovines 链接:http://poj.org/problem?id=2391 题意:有n块区域,第i块区域有ai头奶牛,以及一个可以容纳bi ...
- POJ2391 Ombrophobic Bovines(网络流)(拆点)
Ombrophobic Bovines Time Limit: 1000MS Memory Limit: 65536K Total Submissions ...
- POJ2391 Ombrophobic Bovines
Ombrophobic Bovines Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 19359 Accepted: 4 ...
- POJ2391 Ombrophobic Bovines 网络流拆点+二分+floyed
题目链接: id=2391">poj2391 题意: 有n块草地,每块草地上有一定数量的奶牛和一个雨棚,并给出了每一个雨棚的容(牛)量. 有m条路径连接这些草地 ,这些路径是双向的, ...
- POJ2391:Ombrophobic Bovines(最大流+Floyd+二分)
Ombrophobic Bovines Time Limit: 1000MSMemory Limit: 65536K Total Submissions: 21660Accepted: 4658 题目 ...
- BZOJ 1738: [Usaco2005 mar]Ombrophobic Bovines 发抖的牛( floyd + 二分答案 + 最大流 )
一道水题WA了这么多次真是.... 统考终于完 ( 挂 ) 了...可以好好写题了... 先floyd跑出各个点的最短路 , 然后二分答案 m , 再建图. 每个 farm 拆成一个 cow 点和一个 ...
- poj 2391 Ombrophobic Bovines, 最大流, 拆点, 二分, dinic, isap
poj 2391 Ombrophobic Bovines, 最大流, 拆点, 二分 dinic /* * Author: yew1eb * Created Time: 2014年10月31日 星期五 ...
- POJ 2391 Ombrophobic Bovines
Ombrophobic Bovines Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 18623 Accepted: 4 ...
- poj 2391 Ombrophobic Bovines(最大流+floyd+二分)
Ombrophobic Bovines Time Limit: 1000MSMemory Limit: 65536K Total Submissions: 14519Accepted: 3170 De ...
随机推荐
- Unity 插件制作笔记(持续更新)
示例: [MenuItem(Menu1/Menu2)] static void TestMenu1() { Debug.log("点击了菜单"); } 导航菜单添加 [MenuIt ...
- 加州大学伯克利分校Stat2.3x Inference 统计推断学习笔记: Section 4 Dependent Samples
Stat2.3x Inference(统计推断)课程由加州大学伯克利分校(University of California, Berkeley)于2014年在edX平台讲授. PDF笔记下载(Acad ...
- ffmpeg]ffmpeg使用参数的中文说明
基本选项: -formats 输出所有可用格式 -f fmt 指定格式(音频或视频格式) -i filename 指定输入文件名,在linux下当然也能指定:0.0(屏幕录制)或摄像头 -y 覆盖已有 ...
- CTO、技术总监、首席架构师的区别
2016年11月30日13:22:26[转] CTO.技术总监.首席架构师的区别 提升自已的能力,比如专业技术,行业发展趋势,技术发展趋势,协调能力,组织能力,管理能力等[技术总监] 需要从技术总监和 ...
- JSP+Servlet+JavaBean统计页面在线访问次数
统计页面浏览次数:使用的是servlet实现统计次数传递给JSP页面 说明:我做的都比较接地气,意思就是比较简单! 效果图如下: 上代码 counter.java(它真的好简单,啥事不干,只是定义一个 ...
- python print输出unicode字符
命令行提示符下,python print输出unicode字符时出现以下 UnicodeEncodeError: 'gbk' codec can't encode character '\u30fb ...
- web前端开发修炼之道--编写高质量代码
想想自己的页面实现是否糟糕 Web标准--结构.样式和行为的分离 Web标准可分为三个部分:结构标准.样式标准.行为标准. 结构标准包括XML标准.XHTML标准.HTML标准 样式标准主要是指的CS ...
- AppleHDA 10.9.3 disassm 1
1.通过AppleHDAFunctionGroupFactory::createAppleHDAFunctionGroup(DevIdStruct *)实际创建相应的 AppleHDAFunction ...
- java校验时间格式 HH:MM
package com; import java.text.SimpleDateFormat; import java.util.Date; /** * @author Gerrard */ publ ...
- C#------如何判断输入的是否为纯数字
private void Btn_OK_Click(object sender, EventArgs e) { IDormitoryAdminCardService aservice = new Do ...