Ombrophobic Bovines

Time Limit: 1000MS Memory Limit: 65536K

Total Submissions: 16539 Accepted: 3605

Description

FJ’s cows really hate getting wet so much that the mere thought of getting caught in the rain makes them shake in their hooves. They have decided to put a rain siren on the farm to let them know when rain is approaching. They intend to create a rain evacuation plan so that all the cows can get to shelter before the rain begins. Weather forecasting is not always correct, though. In order to minimize false alarms, they want to sound the siren as late as possible while still giving enough time for all the cows to get to some shelter.

The farm has F (1 <= F <= 200) fields on which the cows graze. A set of P (1 <= P <= 1500) paths connects them. The paths are wide, so that any number of cows can traverse a path in either direction.

Some of the farm’s fields have rain shelters under which the cows can shield themselves. These shelters are of limited size, so a single shelter might not be able to hold all the cows. Fields are small compared to the paths and require no time for cows to traverse.

Compute the minimum amount of time before rain starts that the siren must be sounded so that every cow can get to some shelter.

Input

* Line 1: Two space-separated integers: F and P

  • Lines 2..F+1: Two space-separated integers that describe a field. The first integer (range: 0..1000) is the number of cows in that field. The second integer (range: 0..1000) is the number of cows the shelter in that field can hold. Line i+1 describes field i.

  • Lines F+2..F+P+1: Three space-separated integers that describe a path. The first and second integers (both range 1..F) tell the fields connected by the path. The third integer (range: 1..1,000,000,000) is how long any cow takes to traverse it.

Output

* Line 1: The minimum amount of time required for all cows to get under a shelter, presuming they plan their routes optimally. If it not possible for the all the cows to get under a shelter, output “-1”.

Sample Input

3 4

7 2

0 4

2 6

1 2 40

3 2 70

2 3 90

1 3 120

Sample Output

110

Hint

OUTPUT DETAILS:

In 110 time units, two cows from field 1 can get under the shelter in that field, four cows from field 1 can get under the shelter in field 2, and one cow can get to field 3 and join the cows from that field under the shelter in field 3. Although there are other plans that will get all the cows under a shelter, none will do it in fewer than 110 time units.

Source

USACO 2005 March Gold

一道神伤的题,敲完Dinic结果不对,以为自己的最大流敲错了,后来知道要拆点,搞了一天的TLE加WA

#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 LL long long
#define PI acos(-1.0)
#define MMM 0x3f3f3f3f
#define RR freopen("input.txt","r",stdin)
#define WW freopen("output.txt","w",stdout) const LL INF = 1e15; const int Max = 410; struct node
{
int v;
int w;
int next;
} Edge[321000];
LL M[Max][Max];
int ww[Max],c[Max];
int F,P,top;
int s,t;
int vis[Max];
int Sum;
int Head[Max],cur[Max];
void Build(int u,int v,int w)
{
Edge[top].v=v;
Edge[top].w=w;
Edge[top].next=Head[u];
Head[u]=top++;
Edge[top].v=u;
Edge[top].w=0;
Edge[top].next=Head[v];
Head[v]=top++;
}
void init()
{
for(int i=1; i<=F; i++)
{
for(int j=i; j<=F; j++)
{ M[i][j]=M[j][i]=INF;
}
}
}
void Floyd()
{
for(int k=1; k<=F; k++)
{
for(int i=1; i<=F; i++)
{
for(int j=1; j<=F; j++)
{
if(M[i][j]>M[i][k]+M[k][j])
M[i][j]=M[i][k]+M[k][j];
}
}
}
}
void ReBuild(LL MaxNum)
{
top=0;
memset(Head,-1,sizeof(Head));
for(int i=1; i<=F; i++)
{
Build(s,i,ww[i]);
Build(i+F,t,c[i]);
}
for(int i=1; i<=F; i++)
{
Build(i,i+F,MMM);
}
for(int i=1; i<=F; i++)
{
for(int j=i+1; j<=F; j++)
{
if(M[i][j]<=MaxNum)
{
Build(i,j+F,MMM);
Build(j,i+F,MMM);
}
}
}
}
int BFS()
{
memset(vis,0,sizeof(vis));
queue<int >Q;
Q.push(0);
vis[0]=1;
while(!Q.empty())
{
int a=Q.front();
Q.pop();
for(int i=Head[a]; i!=-1; i=Edge[i].next)
{
if(Edge[i].w>0&&!vis[Edge[i].v])
{
vis[Edge[i].v]=vis[a]+1;
Q.push(Edge[i].v);
}
}
}
return vis[t];
}
int DFS(int star,int num)
{
if(star==t||num==0)
{
return num;
}
int data=0;
int ant;
for(int& i=cur[star]; i!=-1; i=Edge[i].next)//不加&会超时,请大神指教
{
if(vis[star]+1==vis[Edge[i].v]&&(ant=DFS(Edge[i].v,min(Edge[i].w,num)))>0)
{
Edge[i].w-=ant;
Edge[i^1].w+=ant;
num-=ant;
data+=ant;
if(!num)
{
break;
}
}
}
return data;
}
int Dinic()
{
int ant=0;
while(BFS())
{
for(int i=0; i<=t; i++)
{
cur[i]=Head[i];
}
ant+=DFS(s,MMM);
}
return ant;
}
void Search()
{
LL L=1,R=INF-1;
LL ans=-1;
int ant;
while(L<=R)
{
LL mid=(L+R)/2;
ReBuild(mid);
ant=Dinic();
if(ant>=Sum)
{
ans=mid;
R=mid-1;
}
else
{
L=mid+1;
}
}
cout<<ans<<endl;
}
int main()
{
int u,v,w;
while(~scanf("%d%d",&F,&P))
{
init();
Sum=0;
s=0;
t=2*F+1;
for(int i=1; i<=F; i++)
{
scanf("%d%d",&ww[i],&c[i]);
Sum+=ww[i];
}
for(int i=1; i<=P; i++)
{
scanf("%d %d %d",&u,&v,&w);
if(M[u][v]>w)
{
M[u][v]=M[v][u]=w;
}
}
Floyd();
Search();
}
return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

Ombrophobic Bovines 分类: POJ 图论 最短路 查找 2015-08-10 20:32 2人阅读 评论(0) 收藏的更多相关文章

  1. 选择排序 分类: 算法 c/c++ 2014-10-10 20:32 509人阅读 评论(0) 收藏

    选择排序(假设递增排序) 每次选取从当前结点到末尾结点中最小的一个与当前结点交换,每一轮固定一个元素位置. 时间复杂度O(n^2),空间复杂度O(1).下面的示例代码以带头结点的链表为存储结构: #i ...

  2. A Knight's Journey 分类: POJ 搜索 2015-08-08 07:32 2人阅读 评论(0) 收藏

    A Knight's Journey Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 35564 Accepted: 12119 ...

  3. 哈希-Snowflake Snow Snowflakes 分类: POJ 哈希 2015-08-06 20:53 2人阅读 评论(0) 收藏

    Snowflake Snow Snowflakes Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 34762 Accepted: ...

  4. Wormholes 分类: POJ 2015-07-14 20:21 21人阅读 评论(0) 收藏

    Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 35235   Accepted: 12861 Descr ...

  5. DNA Sorting 分类: POJ 2015-06-23 20:24 9人阅读 评论(0) 收藏

    DNA Sorting Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 88690 Accepted: 35644 Descrip ...

  6. Binary Tree 分类: POJ 2015-06-12 20:34 17人阅读 评论(0) 收藏

    Binary Tree Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6355   Accepted: 2922 Descr ...

  7. Self Numbers 分类: POJ 2015-06-12 20:07 14人阅读 评论(0) 收藏

    Self Numbers Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 22101   Accepted: 12429 De ...

  8. Poj 2559 最大矩形面积 v单调栈 分类: Brush Mode 2014-11-13 20:48 81人阅读 评论(0) 收藏

    #include<iostream> #include<stack> #include<stdio.h> using namespace std; struct n ...

  9. Dijkstra with priority queue 分类: ACM TYPE 2015-07-23 20:12 4人阅读 评论(0) 收藏

    POJ 1511 Invitation Cards(单源最短路,优先队列优化的Dijkstra) //================================================= ...

随机推荐

  1. jquery垂直展开折叠手风琴二级菜单

    摘要:jquery实现垂直展开二级菜单 最近新开发一个简单项目,用到左侧两级的菜单.找找了手头的文件,竟然没有现成的代码,算了,去网上找找整理下吧. 注:jquery-1.8.3.min.js需要下载 ...

  2. java io读书笔记(1)综述

    学习,是要持之以恒的,再读一本书,坚持. Java™ I/O, 2nd Edition By Elliotte Rusty Harold ............................... ...

  3. swift语言实战晋级-第9章 游戏实战-跑酷熊猫-9-10 移除平台与视差滚动

    9.9 移除场景之外的平台 用为平台是源源不断的产生的,如果不注意销毁,平台就将越积越多,虽然在游戏场景中看不到.几十个还看不出问题,那几万个呢?几百万个呢? 所以我们来看看怎么移除平台,那什么样的平 ...

  4. Leetcode: Flatten Nested List Iterator

    Given a nested list of integers, implement an iterator to flatten it. Each element is either an inte ...

  5. php第三方登陆

    学习之前,请大家先看一下oAuth协议. 首先呢,我们进入QQ互联的官方网站 http://connect.qq.com登入我们自己的QQ号,没有QQ号的小伙伴可以忽略本篇博文分享!

  6. struts配置请求后缀,将.action改为.do、.doaction_2015.01.04

    <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "- ...

  7. 夺命雷公狗ThinkPHP项目之----企业网站28之网站前台左侧导航的实现

    我们基于刚才在model层的找顶级分类的代码在进行修改即可: <?php namespace Home\Controller; use Think\Controller; class Commo ...

  8. 夺命雷公狗ThinkPHP项目之----企业网站25之网站前台面包屑导航URL的完善

    如果想取出面包屑导航的url那么就必须在model层里面进行多取一个了: <?php namespace Home\Model; use Think\Model; class CategoryM ...

  9. PAT乙级 1002. 写出这个数 (20)

    1002. 写出这个数 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入一个自然数n,计算其各位数字 ...

  10. php setcookie 讲解

    1.setcookie 中 $value 值不能为数组 e.g a.$arr = array('hh','bb');setcookie('username',$arr);这种不会生效的 如果确实要放数 ...