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. Greenplum:学习资料

    Greenplum技术浅析:http://www.cnblogs.com/end/archive/2012/08/17/2644290.html Greenplum 数据库架构分析:http://ww ...

  2. 转:python字符串/元组/列表/字典互转

    #-*-coding:utf-8-*-  #1.字典 dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ...

  3. [原创]java WEB学习笔记83:Hibernate学习之路---双向 1-n介绍,关键点解释,代码实现,set属性介绍(inverse,cascade ,order-by )

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  4. Python学习总结15:时间模块datetime & time & calendar (二)

    二 .datetime模块  1. datetime中常量 1)datetime.MINYEAR,表示datetime所能表示的最小年份,MINYEAR = 1. 2)datetime.MAXYEAR ...

  5. C++: getline函数

    转自http://blog.sina.com.cn/s/blog_60263c1c0101ck25.html 学习C++的同学可能都会遇到一个getline()函数,譬如在C++premer中,标准s ...

  6. poj: 1003

    简单题 #include <iostream> #include <stdio.h> #include <string.h> #include <stack& ...

  7. $.getJSON异步请求和同步请求

    先说一下我遇到的问题吧,我之前的一个函数想调用上一个函数的返回值,但是它的返回值一直为空,后来翻了一些资料才明白是异步请求在作怪,不多说,看例子,这是我之前有返回值函数的代码: function ge ...

  8. ligerui+json_002_Grid用法、属性总结

    原文更全面,地址: http://blog.csdn.net/dxnn520/article/details/8216560 // ================================== ...

  9. ADIv5.2

    ADI:ARM Debug Interface,出到现在共有五代: 1)version1 and version 2:只针对ARM7TDMI和ARM9的processor: 2)version 3:只 ...

  10. zw版【转发·台湾nvp系列Delphi例程】HALCON EdgesImage

    zw版[转发·台湾nvp系列Delphi例程]HALCON EdgesImage procedure TForm1.Button1Click(Sender: TObject);var img0, im ...