poj2391:http://poj.org/problem?id=2391

题意:一个人有n个农场,每个农场都一个避雨的地方,每个农场有一些牛,每个避雨的地方能容纳牛的数量是有限的。农场之间有一些道路可以连通。现在给出每个农场的牛的数量以及每个避雨点的值,问你所有的牛都找到一个避雨点的时间最短是多少。
题解:本题个人认为对于初学者来说,比较难了。看了别人的题解,本题的考察的知识点有:Floyd+二分+网络最大流,以及图论里面的拆点和建图。首先:对于所有的牛来说,如果农场是连通的,则最短的时间最坏的情况是任意两点之间距离的最大值所以要用Floyd来求n源最短路。然后最初最大的那个值。第二:建图,超级源点0,会点2*n+1,然后拆点,把那个农场拆成2*n个点,
例如:4个点的话
      1      5
      2      6
      3      7
      4      8

然后建边,以上的点,左边的点与0点建边,边权的容量为每个农改现在的牛的数量,右边的点与会点建边,边的容量为每个避雨点的容量。然后1和5之间,2和6之间建边,边权INF,然后二分答案(就是刚才的那个最大数值),对于任意的两点之间,如果两点之间的距离小于这个最大值,说明可以由i这个点牛向j移动所以i和j+n之间要建边,边权INF
每一二分答案,跑最大流,如果最大流等于牛的总数,说明这个距离满足条件,继续缩小距离再跑,知道不行就停止,则此时的距离就是最短的距离,保证所有牛都能找到避雨点的距离。
注意:本题的数据,距离会爆出int

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
const int INF=;
const int MAXN=;
const long long INFs=100000000000000LL;
int val1[MAXN],val2[MAXN];
struct Node{
int f;
int c;
};
long long dist[MAXN][MAXN];//求最短路
int pre[MAXN];//网络流的分层
Node map[MAXN][MAXN];//网络流的图
int n,m;
int se,sx;//会点和源点
bool BFS(){//层次网络
memset(pre,,sizeof(pre));
queue<int>Q;
Q.push();
pre[]=;
while(!Q.empty()){
int v=Q.front();
Q.pop();
for(int i=;i<=*n+;i++)
if(!pre[i]&&map[v][i].c-map[v][i].f){
pre[i]=pre[v]+;
Q.push(i);
}
}
return pre[se]!=;
}
int dinic(int pos,int flow){//网路流
int f=flow;
if(pos==se)
return flow;
for(int i=;i<=*n+;i++){
if(map[pos][i].c-map[pos][i].f&&pre[i]==pre[pos]+){
int a=map[pos][i].c-map[pos][i].f;
int temp=dinic(i,min(a,flow));
map[pos][i].f+=temp;
map[i][pos].f-=temp;
flow-=temp;
}
}
return f-flow;
}
int slove(){//总流
int sum=;
while(BFS())
sum+=dinic(sx,INF);
return sum;
}
void build(long long limit){//建图
memset(map,,sizeof(map));
for(int i=;i<=n;i++)
if(val1[i]){
map[][i].c=val1[i];
map[][i].f=;
map[i][i+n].c=INF;
map[i][i+n].f=;
}
for(int i=;i<=n;i++){
if(val2[i]){
map[i+n][*n+].c=val2[i];
map[i+n][*n+].f=;
}
}
for(int i=;i<=n;i++)
for(int j=;j<=n;j++){
if(dist[i][j]<=limit&&i!=j){
map[i][j+n].c=INF;
map[i][j+n].f=;
}
}
}
long long Floyd(){//求n源最短路
for(int k=;k<=n;k++)
for(int i=;i<=n;i++)
for(int j=;j<=n;j++){
if(i!=k&&i!=j&&k!=j&&dist[i][k]+dist[k][j]<dist[i][j])
dist[i][j]=dist[i][k]+dist[k][j];
}
long long ans=;//注意这里初始化,因为一下的可能不会执行,可能没有满足条件ans
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
if(dist[i][j]<INFs&&dist[i][j]>ans)
ans=dist[i][j];
return ans;
}
void init(){//初始化
memset(val1,,sizeof(val1));
memset(val2,,sizeof(val2));
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
dist[i][j]=INFs;
}
int main(){
int c,f,u,v,sum;long long w;
while(~scanf("%d%d",&n,&m)){
init();sum=;sx=;se=*n+;
for(int i=;i<=n;i++){
scanf("%d%d",&f,&c);
val1[i]=f;val2[i]=c;
sum+=f;
}
for(int i=;i<=m;i++){
scanf("%d %d %I64d",&u,&v,&w);
if(w<dist[u][v])
dist[u][v]=dist[v][u]=w;
}
long long r=Floyd(),ans=-,l=;
while(l<=r){//二分答案,不断缩小答案
long long mid=(l+r)/;
build(mid);
if(slove()>=sum){
r=mid-;ans=mid;
}
else
l=mid+;
}
printf("%I64d\n",ans);
}
}

Ombrophobic Bovines的更多相关文章

  1. POJ 2391 Ombrophobic Bovines

    Ombrophobic Bovines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 18623   Accepted: 4 ...

  2. poj 2391 Ombrophobic Bovines(最大流+floyd+二分)

    Ombrophobic Bovines Time Limit: 1000MSMemory Limit: 65536K Total Submissions: 14519Accepted: 3170 De ...

  3. Ombrophobic Bovines 分类: POJ 图论 最短路 查找 2015-08-10 20:32 2人阅读 评论(0) 收藏

    Ombrophobic Bovines Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16539 Accepted: 3605 ...

  4. POJ2391 Ombrophobic Bovines(网络流)(拆点)

                         Ombrophobic Bovines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions ...

  5. BZOJ 1738: [Usaco2005 mar]Ombrophobic Bovines 发抖的牛( floyd + 二分答案 + 最大流 )

    一道水题WA了这么多次真是.... 统考终于完 ( 挂 ) 了...可以好好写题了... 先floyd跑出各个点的最短路 , 然后二分答案 m , 再建图. 每个 farm 拆成一个 cow 点和一个 ...

  6. POJ2391 Ombrophobic Bovines

    Ombrophobic Bovines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 19359   Accepted: 4 ...

  7. POJ 2391 Ombrophobic Bovines (Floyd + Dinic +二分)

    Ombrophobic Bovines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11651   Accepted: 2 ...

  8. poj 2391 Ombrophobic Bovines, 最大流, 拆点, 二分, dinic, isap

    poj 2391 Ombrophobic Bovines, 最大流, 拆点, 二分 dinic /* * Author: yew1eb * Created Time: 2014年10月31日 星期五 ...

  9. poj2391 Ombrophobic Bovines 拆点+二分法+最大流

    /** 题目:poj2391 Ombrophobic Bovines 链接:http://poj.org/problem?id=2391 题意:有n块区域,第i块区域有ai头奶牛,以及一个可以容纳bi ...

  10. POJ2391:Ombrophobic Bovines(最大流+Floyd+二分)

    Ombrophobic Bovines Time Limit: 1000MSMemory Limit: 65536K Total Submissions: 21660Accepted: 4658 题目 ...

随机推荐

  1. nanosleep纳秒级延迟

    //函数原型 int nanosleep(struct timespec *req, struct timespec *rem) //参数列表: // req:要求的睡眠时间 // rem:剩余的睡眠 ...

  2. hibernate批量删除和更新数据

    转载自:http://blog.csdn.net/yuhua3272004/article/details/2909538 Hibernate3.0 採用新的基于ANTLR的HQL/SQL查询翻译器, ...

  3. ini格式数据生成与解析具体解释

    ini格式数据生成与解析具体解释 1.ini格式数据长啥样? watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/ ...

  4. Android 自定义View高级特效,神奇的贝塞尔曲线

    效果图 效果图中我们实现了一个简单的随手指滑动的二阶贝塞尔曲线,还有一个复杂点的,穿越所有已知点的贝塞尔曲线.学会使用贝塞尔曲线后可以实现例如QQ红点滑动删除啦,360动态球啦,bulabulabul ...

  5. java的继承机制

    这次我想深入探究以下java里类的继承机制.       我们知道,继承是java设计里的一个失败的地方.高司令说过:如果让他重新设计java的话,他会把继承去掉.而java里继承到底怎么了,会这么不 ...

  6. rabbitmq 消息持久化

    rabbitmq 消息持久化 2016-02-18 11:19 224人阅读 评论(0) 收藏 举报  分类: 综合(15)  版权声明:本文为博主原创文章,未经博主允许不得转载. 二: 任务分发 & ...

  7. 关于URL 解码, 编码

    由于近期客户需要用到CA认证,此CA认证采用的是URL方式出传值 使用指定的编码对象将 URL 编码的字符串转换为已解码的字符串. 编码个人理解就是将某字符串以某种方式储存起来,而解码则以其编码格式得 ...

  8. Android开发手记(30) 触摸及手势操作

    触摸操作在现在智能手机系统中起到举足轻重的作用,本文将对安卓中的触摸以及一些简单手势的操作进行简单的介绍. 1.触摸 首先是关于触摸的判断,有两种方法可以判断的触摸操作. (1)setOnTouchL ...

  9. ValidationContext

    .NET 4 和Silverlight 中可以使用以下方法: ? public static void Validate(this Entity entity) {     // prepare th ...

  10. SSL VPN 详解

    SSL VPN是专栏VPN系列技术原理的最后一篇,SSL VPN作为远程接入型的VPN,已经具备非常广阔的前景,它的主要适应场景是取代L2TP Over IPSec,但功能要比L2TP Over IP ...