描述

话说这日,李逍遥与阿奴正欲前往桃花源拿寿葫芦,突然电闪雷鸣,天降暴雨,弄得两人措手不及,只得到附近的树洞避雨。

"哎,大理不是本应旱灾的吗?怎么会突降暴雨呢?"李逍遥嘀咕道。

"大概程序又出bug了吧。"阿奴回答到。(瀑布汗,这绝对是盗版的仙剑)
"这应该是100年来降雨最多的一次了!"李逍遥感叹。

"不对。事实上,93年前,从年初到一年的这个时候为止,下的雨是今年的五倍。"
"哦",李逍遥想了想了,"这么说,这是93年中气候最差的一年。"
"还是不对,这其实是23年来气候最糟糕的。"阿奴又一次打断他的话。

……………………………………………………………………………………
他们就这样讨论了很长很长时间。

亲爱的OIers,他们不在乎,你们是在乎的,不是吗?

若已知大理历史上不同年份的降雨量,现有一系列以"X年是自Y年以来雨量最多的年份"形式给出的陈述,你的任务就是判断这些陈述是正确,可能正确,还是错误的。

若一个陈述满足下列情况,我们就说它是正确的:
·X年和Y年以及这两年间的任意年份的降雨量都是已知的。

·X年的降雨量最多不得超过Y年。

·对任意年份Z满足Y<Z<X,降雨量都比X年的少。

当我们用降雨量给年份赋值,却缺少必要的信息来使这个陈述正确,我们说这个陈述可能正确。其他情况下这个陈述是错误的。

格式

输入格式

第一行是一个整数n,表示已知信息中的所含的年份数目。接下来的n行表示每个年份的降雨信息。其中第i行包含两个整数yi,ri(-10^9 <= yi <= 10^9,0 <= ri <= 10^9),表示第yi年的降雨量为ri毫升(注意每年的降雨量可以是一个任意的非负整数,上述范围仅仅是输入信息中数据的范围)。数据保证yi < yi+1 (1 <= i < n)。

第二部分首先是一个整数m,表示判断的陈述的数目。接下来的m行每行有两个整数Y,X(-10^9 <= Y < X <= 10^9),意义如上所述。

输出格式

输出应该包含m行,对应于m个询问。如果陈述为正确的则输出"true"(不含引号,下同),为假则输出"false",可能为真可能为假则输出"maybe"。

样例1

样例输入1[复制]

 
4
2002 4920
2003 5901
2004 2832
2005 3890
2
2002 2005
2003 2005

样例输出1[复制]

 
false
true

样例2

样例输入2[复制]

 
3
1985 5782
1995 3048
2005 4890
2
1985 2005
2005 2015

样例输出2[复制]

 
maybe
maybe

限制

1s

提示

40%的输入数据满足 n<=50,m<=10
80%的输入数据满足 n<=5000,m<=1000
100%的输入数据满足 n<=50000,m<=10000

来源

经典问题

1591346 ksq2013 1067 Accepted 2196 kb 128 ms C++/Edit 1287 B 2016-08-14 21:57:55

受教了!

第一次学zkw线段树(不可谓短小精悍),按标程一步步写的。参考博客:http://www.cnblogs.com/ccz181078/p/5468357.html

lower_bound()或upper_bound()返回值见博客:http://blog.csdn.net/niushuai666/article/details/6734403

#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
const int inf=0x3f3f3f3f;
static int M=65536;
int n,q,x[50001],y[50001],mx[131072];
inline int read()
{
int x=0,c=getchar(),f=1;
while(c>57||c<48){if(c=='-')f=-1;c=getchar();}
while(c>47&&c<58)x=x*10+c-48,c=getchar();
return x*f;
}
inline int query(int l,int r)
{
int sum=-inf;
for(l+=M+1,r+=M+3;l^r^1;l>>=1,r>>=1){
if(~l&1)sum=max(sum,mx[l^1]);
if(r&1)sum=max(sum,mx[r^1]);
}
return sum;
}
int main()
{
n=read();
while(n*2+10<M/2)M>>=1;
for(int i=0;i<n;i++)
x[i]=read(),y[i]=read();
x[n]=inf;
for(int i=0;i<n;i++)
mx[i+M+2]=y[i];
for(int i=M-1;i;i--){
int l=i<<1,r=l^1;
mx[i]=max(mx[l],mx[r]);
}
q=read();
while(q--){
int a=read(),b=read();
int l=lower_bound(x,x+n,a)-x;
int r=upper_bound(x,x+n,b)-x-1;
if(a>b){puts("false");continue;}
bool lk=x[l]==a,rk=x[r]==b;
int Mx=query(l+lk,r-rk);
if(lk&&Mx>=y[l]||rk&&Mx>=y[r]||lk&&rk&&y[l]<y[r])
{puts("false");continue;}
if(r-l==b-a&&lk&&rk&&y[l]>=y[r])
{puts("true");continue;}
puts("maybe");
}
return 0;
}

bzoj1067 降雨量&&vijos1265 暴风雨的更多相关文章

  1. BZOJ-1067 降雨量 线段树+分类讨论

    这道B题,刚的不行,各种碎点及其容易忽略,受不鸟了直接 1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 2859 ...

  2. bzoj1067 降雨量

    Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意 Y<Z<X,Z年的降雨量严格小于X年.例如2002,2003, ...

  3. bzoj1067降雨量

    True和False都好搞 Maybe的情况: 1.Y年和X年的降雨量已知,X年的降雨量不超过Y年的降雨量,从Y+1到X-1年中存在至少一年的降雨量未知,从Y+1到X-1年中已知的降雨量都小于X年的降 ...

  4. 备战NOIP每周写题记录(一)···不间断更新

    ※Recorded By ksq2013 //其实这段时间写的题远远大于这篇博文中的内容,只不过那些数以百记的基础题目实在没必要写在blog上; ※week one 2016.7.18 Monday ...

  5. [BZOJ1067][SCOI2007]降雨量

    [BZOJ1067][SCOI2007]降雨量 试题描述 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意 Y<Z<X,Z年的降雨量严格 ...

  6. 【BZOJ1067】[SCOI2007]降雨量 RMQ+特判

    [BZOJ1067][SCOI2007]降雨量 Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年 ...

  7. 【BZOJ1067】【POJ2637】降雨量

    1067: [SCOI2007]降雨量 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 3004  Solved: 767[Submit][Status] ...

  8. BZOJ1067 [SCOI2007]降雨量 线段树

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1067 题意概括 给定n组整数对(Xi,Yi),当Xi<Xj且Yi>=Yj时,如果对于任 ...

  9. 【BZOJ1067】【SCOI2007】降雨量

    新人求助,降雨量那题,本机AC提交AC 原题: 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X年.例 ...

随机推荐

  1. Java Android HTTP实现总结

    Java Android HTTP实现总结 Http(Hypertext Transfer Protocol)超文本传输协议,是一个基于请求/响应模式的无状态的协议,Http1.1版给出了持续连接的机 ...

  2. iOS开发init方法解析

    自定义的init方法,都必须调用父类的init方法. 一般情况下为: - (id)init {      [super init];      xxx = xxx; }   通常情况下,这种模式可以满 ...

  3. 【代码笔记】iOS-手机号验证

    代码: - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. // ...

  4. fir终端打包,亲测可用

    1.注册fir.拿到token 2.安装 fir-cli 使用 Ruby 构建, 无需编译, 只要安装相应 gem 即可. $ ruby -v # > 1.9.3 $ gem install f ...

  5. location.href参数丢失

    今天用location.href跳转页面的时候遇到了一个问题. 给一个按钮添加点击事件,在js里实现跳转页面,并传递一个参数. <a class="btn btn-primary&qu ...

  6. Android中TextView添加删除线

    项目中的需求~~~~ 商城中物品的一个本身价格,还有一个就是优惠价格...需要用到一个删除线. public class TestActivity extends Activity { private ...

  7. Mongodb Manual阅读笔记:CH3 数据模型(Data Models)

    3数据模型(Data Models) Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mon ...

  8. 小议如何使用APPLY

    简介 如果你打算为在结果集中的每条记录写一个调用表值函数或者表值表达式的select语句,那么你就能用到APPLY 操作符来实现.一般又两种形式写法: 第一种格式就是CROSS APPLY.这种格式可 ...

  9. apache https配置

    1.  确认是否安装ssl模块 是否有mod_ssl.so文件 2.  生成证书和密钥 linux下 步骤1:生成密钥 命令:openssl genrsa 1024 > server.key 说 ...

  10. 漏洞科普:对于XSS和CSRF你究竟了解多少

    转自:http://www.freebuf.com/articles/web/39234.html 随着Web2.0.社交网络.微博等等一系列新型的互联网产品的诞生,基于Web环境的互联网应用越来越广 ...