http://poj.org/problem?id=3658

Description

The oppressively hot summer days have raised the cows' clamoring to its highest level. Farmer John has finally decided to build an artificial lake. For his engineering studies, he is modeling the lake as a two-dimensional landscape consisting of a contiguous sequence of N soon-to-be-submerged levels (1 ≤ N ≤ 100,000) conveniently numbered 1..N from left to right.

Each level i is described by two integers, its width Wi (1 ≤ Wi ≤ 1,000) and height (like a relative elevation) Hi (1 ≤ Hi ≤ 1,000,000). The heights of FJ's levels are unique. An infinitely tall barrier encloses the lake's model on the left and right. One example lake profile is shown below.

         *             *  :

* * :

* * 8

* *** * 7

* *** * 6

* *** * 5

* ********** 4 <- height

* ********** 3

*************** 2

*************** 1

Level | 1 |2| 3 |

In FJ's model, he starts filling his lake at sunrise by flowing water into the bottom of the lowest elevation at a rate of 1 square unit of water per minute. The water falls directly downward until it hits something, and then it flows and spreads as room-temperature water always does. As in all good models, assume that falling and flowing happen instantly. Determine the time at which each elevation's becomes submerged by a single unit of water.

WATER              WATER OVERFLOWS

| |

* | * * | * * *

* V * * V * * *

* * * .... * *~~~~~~~~~~~~*

* ** * *~~~~** : * *~~~~**~~~~~~*

* ** * *~~~~** : * *~~~~**~~~~~~*

* ** * *~~~~**~~~~~~* *~~~~**~~~~~~*

* ********* *~~~~********* *~~~~*********

*~~~~********* *~~~~********* *~~~~*********

************** ************** **************

************** ************** ************** After 4 mins After 26 mins After 50 mins

Lvl 1 submerged Lvl 3 submerged Lvl 2 submerged

Warning: The answer will not always fit in 32 bits.

Input

* Line 1: A single integer: N
* Lines 2..N+1: Line i+1 describes level i with two space-separated integers: Wi and Hi

Output

* Lines 1..N: Line i contains a single integer that is the number of minutes that since sunrise when level #i is covered by water of height 1.

Sample Input


Sample Output


题意:

给出N个连续的平台,他们各有宽度,且高度不同。先向高度最低的平台灌水,直到灌满溢出,流向其他的平台,直至所有平台都被覆盖。已知每分钟注入高为1宽为1的水,求每个平台恰好被高为1的水覆盖的时间。

思路:

先记录每个平台的高度与宽度以及他们的左、右平台,找到最低的平台,开始灌水。灌满最低平台后,相当于该平台消失,寻找下一流向哪个平台,再更新左右平台,直到最高的平台被水覆盖。

分析:

1、对于每个平台,L代表其左边的平台标号,R代表其右边的平台标号,随着平台被淹没,R,L会随之改变。

2、平台标号为1~n,其两侧平台0和n+1高度初始化为正无穷作为界线,因此只需统计淹没了n个平台的情况即可。

3、先找到最低的平台标号。淹没当前平台后,更新水流溢出后,即将流向的平台标号。

4、然后找要淹没的那个平台,此平台要比两侧平台低。

5、将当前平台的水注满到与两侧较矮平台齐平的高度,将较矮的平台宽度更新为加上当前平台后的宽度,与此同时,更新当前平台两侧的平台的左右平台标号。

注意:数据不保证答案全部在32位整型变量的范围内,要用long long 。

代码:

 #include <stdio.h>
#include <string.h>
#include <iostream>
#include <string>
#include <math.h>
#include <algorithm>
#include <queue>
#include <set>
const int INF=0x3f3f3f3f;
using namespace std;
#define maxn 100010 struct node{
long long wide;
long long high;
int left;
int right;
}a[maxn];
int n;
long long ans[maxn];//存答案,注意是long long int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%lld %lld",&a[i].wide,&a[i].high);
}
for(int i=;i<=n+;i++)//左右平台初始化
{
a[i].left=i-;
a[i].right=i+;
} a[].high=INF;//高度设为无限高
a[n+].high=INF; int MIN=INF;
int m;
for(int i=;i<=n;i++)//寻找高度最低的平台
{
if(a[i].high<MIN)
{
MIN=a[i].high;
m=i;
}
} int L,R;
long long sum=;//计时器,注意是long long
int num=;//已经淹没平台个数
while(num<=n)
{
num++;
sum+=a[m].wide;//根据题意,先加一层作为答案
ans[m]=sum; L=a[m].left;
R=a[m].right;
sum+=(min(a[L].high,a[R].high)-a[m].high-)*a[m].wide;//填满该坑,-1是因为开始先加了一层 a[L].right=R;//更新左平台
a[R].left=L;//更新右平台
if(a[L].high<a[R].high)//更新宽度
{
a[L].wide+=a[m].wide;
m=L;
}
else
{
a[R].wide+=a[m].wide;
m=R;
} //更新下一流向平台标号
while()
{
R=a[m].right;
L=a[m].left;
if(a[L].high<a[m].high)
m=L;
else if(a[R].high<a[m].high)
m=R;
else
break;
}
}
for(int i=;i<=n;i++)
{
printf("%lld\n",ans[i]);
}
return ;
}

最新文章

  1. wghd的git代码仓库分支管理说明【转】
  2. 例题6-5 Boxes in a line uVa12657
  3. 2014-9-17二班----8 web project
  4. Mongodb 安装和启动
  5. Hibernate学习笔记(1)Hibernate构造
  6. jqgrid的外观重绘
  7. Nginx+Python+uwsgi+Django的web开发环境安装及配置
  8. Unity3D手机斗地主游戏开发实战(01)_发牌功能实现
  9. 系列文章|OKR与敏捷(二):实现全栈敏捷
  10. QT背景颜色,菜单颜色更改
  11. 31.C++-虚函数之构造函数与析构函数分析
  12. PHP 3 函数
  13. 解决插值表达式闪烁问题 - v-cloak
  14. redis 集群搭建: redis-cluster
  15. 7.Deque的应用案例-回文检查
  16. 用Executors工具类创建线程池
  17. Python 1行代码实现文本分类(实战笔记),含代码详细说明及运行结果
  18. Linxu系统修改文件描述符
  19. VS2010/MFC编程入门之二十五(常用控件:组合框控件Combo Box)
  20. xgboost和gbdt区别

热门文章

  1. 吴裕雄--天生自然JAVA SPRING框架开发学习笔记:Spring框架的基本思想
  2. 一天一个设计模式——Prototype 原型模式
  3. 使用AJAX(阿贾克斯)创建级联菜单
  4. JAVA多线程的基础
  5. ES6 之 对象的扩展
  6. 自动生成返回Json数据的toString()方法
  7. ubuntu 插网线无法上网解决方案
  8. navicat for mysql连接数据库报错1251
  9. 用IMX6开发板创建Android模拟器
  10. 14)载入png图片