Ombrophobic Bovines 分类: POJ 图论 最短路 查找 2015-08-10 20:32 2人阅读 评论(0) 收藏
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) 收藏的更多相关文章
- 选择排序 分类: 算法 c/c++ 2014-10-10 20:32 509人阅读 评论(0) 收藏
选择排序(假设递增排序) 每次选取从当前结点到末尾结点中最小的一个与当前结点交换,每一轮固定一个元素位置. 时间复杂度O(n^2),空间复杂度O(1).下面的示例代码以带头结点的链表为存储结构: #i ...
- 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 ...
- 哈希-Snowflake Snow Snowflakes 分类: POJ 哈希 2015-08-06 20:53 2人阅读 评论(0) 收藏
Snowflake Snow Snowflakes Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 34762 Accepted: ...
- Wormholes 分类: POJ 2015-07-14 20:21 21人阅读 评论(0) 收藏
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 35235 Accepted: 12861 Descr ...
- DNA Sorting 分类: POJ 2015-06-23 20:24 9人阅读 评论(0) 收藏
DNA Sorting Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 88690 Accepted: 35644 Descrip ...
- Binary Tree 分类: POJ 2015-06-12 20:34 17人阅读 评论(0) 收藏
Binary Tree Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6355 Accepted: 2922 Descr ...
- Self Numbers 分类: POJ 2015-06-12 20:07 14人阅读 评论(0) 收藏
Self Numbers Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 22101 Accepted: 12429 De ...
- Poj 2559 最大矩形面积 v单调栈 分类: Brush Mode 2014-11-13 20:48 81人阅读 评论(0) 收藏
#include<iostream> #include<stack> #include<stdio.h> using namespace std; struct n ...
- Dijkstra with priority queue 分类: ACM TYPE 2015-07-23 20:12 4人阅读 评论(0) 收藏
POJ 1511 Invitation Cards(单源最短路,优先队列优化的Dijkstra) //================================================= ...
随机推荐
- nodejs发起HTTPS请求并获取数据
摘要:在网站中有时候需要跨域请求数据,直接用Ajax无法实现跨域,采用其他方式需要根据不同的浏览器做相应的处理.用Nodejs可以很好的解决这些问题,后台引用HTTPS模块,发送和返回的数据均为JSO ...
- 企业Openvpn环境部署
企业Openvpn环境部署 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任 ...
- [Reprint]C++友元函数与拷贝构造函数详解
这篇文章主要介绍了C++友元函数与拷贝构造函数,需要的朋友可以参考下 一.友元函数 1.友元函数概述: (1)友元函数是定义在一个类外的普通函数.友元函数和普通函数的定义一样;在类内必须将该普通函 ...
- 20145207《Java程序设计》第6周学习总结
教材学习内容总结 一.输入/输出 InputStream与Outputstream • 串流设计的概念 从应用程序角度看,将数据从来源取出,可以使用输入串流,将数据写入目的地,可以使用输出串流:在Ja ...
- ARM 寄存器的介绍
ARM 寄存器 31个通用, 32个程序状态寄存器 怎么算的呢: (R0--R15) 16 + 7 + 8 =31 通用 程序状态寄存器: 6 个 共 37 个. 不分组寄存器: ...
- paper 51:图像复原
图像退化: 图像在形成.记录.处理和传输过程中,由于成像系统.记录设备.传输介质和处理方法的不完善,导致图像质量的下降,这种现象叫做图像退化. 图像复原: 就是对退化的图像进行处理,尽可能恢复出原始 ...
- angular 自定义指令 link or controller
Before compilation? – Controller After compilation? – Link var app = angular.module('plunker', []); ...
- 夺命雷公狗jquery---6属性选择器
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- struct2 学习总结
花了近半个月学习了struct2.现大致总结下学习点: 1. struct2 入门以及基本配置(未继承ActionSupport,配置struts.xml文件,execute方法直接返回SUCESS) ...
- zw版【转发·台湾nvp系列例程】HALCON EquHistoImage(Delphi)
zw版[转发·台湾nvp系列例程]HALCON EquHistoImage(Delphi) zw版[转发·台湾nvp系列例程]HALCON EquHistoImage(Delphi) (Delphi ...