Description

我们常常会说这样的话:“\(X\)年是自\(Y\)年以来降雨量最多的”。它的含义是\(X\)年的降雨量不超过\(Y\)年,且对于任意\(Y<Z<X\),\(Z\)年的降雨量严格小于\(X\)年。例如\(2002,2003,2004\)和\(2005\)年的降雨量分别为\(4920,5901,2832\)和\(3890\),则可以说“\(2005\)年是自\(2003\)年以来最多的”,但不能说“\(2005\)年是自\(2002\)年以来最多的”由于有些年份的降雨量未知,有的说法是可能正确也可以不正确的。

Input

输入仅一行包含一个正整数\(n\),为已知的数据。以下\(n\)行每行两个整数\(y_{i}\)和\(r_{i}\),为年份和降雨量,按照年份从小到大排列,即\(y_{i}<y_{i}+1\)。下一行包含一个正整数\(m\),为询问的次数。以下\(m\)行每行包含两个数Y和X,即询问“\(X\)年是自\(Y\)年以来降雨量最多的。”这句话是必真、必假还是“有可能”。

Output

对于每一个询问,输出true,false或者maybe。

Sample Input

6

2002 4920

2003 5901

2004 2832

2005 3890

2007 5609

2008 3024

5

2002 2005

2003 2005

2002 2007

2003 2007

2005 2008

Sample Output

false

true

false

maybe

false

HINT

\(100\%\)的数据满足:\(1 \le n \le 50000, 1 \le m \le 10000, -10^{9} \le y_{i} \le 10^{9}, 1 \le r_{i} \le 10^{9}\)

线段树或rmq都可以做啊。

#include<cstdio>
#include<cstdlib>
using namespace std; #define inf (1<<30)
#define maxn (50010)
#define maxm (10010)
int n,m;
struct node
{
int a,b;
inline void read() { scanf("%d %d",&a,&b); }
friend inline bool operator >(const node &x,const node &y) { return x.b != y.b?x.b>y.b:x.a<y.a; }
friend inline bool operator != (const node &x,const node &y) { return x.a!=y.a||x.b!=y.b; }
}rain[maxn],seg[maxn*4]; inline node Max(const node &x,const node &y) { if (x > y) return x; return y; } inline int find(int key)
{
int l = 1,r = n;
while (l <= r)
{
int mid = (l + r) >> 1;
if (rain[mid].a <= key) l = mid + 1;
else r = mid - 1;
}
return l;
} inline void build(int l,int r,int now)
{
if (l == r) { seg[now] = rain[l]; return; }
int mid = (l + r) >> 1;
build(l,mid,now<<1); build(mid+1,r,now<<1|1);
seg[now] = Max(seg[now<<1],seg[now<<1|1]);
} inline node ask(int l,int r,int now,int ql,int qr)
{
if (ql > qr) return (node){-inf,-inf};
if (l >= ql&&r <= qr) return seg[now];
int mid = (l + r) >> 1;
if (qr <= mid) return ask(l,mid,now<<1,ql,qr);
else if (ql > mid) return ask(mid+1,r,now<<1|1,ql,qr);
else return Max(ask(l,mid,now<<1,ql,mid),ask(mid+1,r,now<<1|1,mid+1,qr));
} int main()
{
freopen("1067.in","r",stdin);
freopen("1067.out","w",stdout);
scanf("%d",&n);
for (int i = 1;i <= n;++i) rain[i].read();
rain[0].a = -inf;
build(1,n,1);
scanf("%d",&m);
for (int i = 1;i <= m;++i)
{
int x,y; scanf("%d %d",&x,&y);
int l = find(x)-1,r = find(y)-1;
if (rain[l].a != x&&rain[r].a != y) printf("maybe\n");
else if (rain[l].a == x && rain[r].a == y)
{
if (ask(1,n,1,l,r-1) != rain[l]||ask(1,n,1,l+1,r) != rain[r]) printf("false\n");
else
{
if (rain[l].b < rain[r].b) printf("false\n");
else
{
if (r-l+1 == y-x+1) printf("true\n");
else printf("maybe\n");
}
}
}
else
{
if (rain[l].a == x)
{
if (ask(1,n,1,l,r) != rain[l]||ask(1,n,1,l+1,r).b == rain[l].b) printf("false\n");
else printf("maybe\n");
}
else
{
if (ask(1,n,1,l+1,r) != rain[r]) printf("false\n");
else printf("maybe\n");
}
}
}
fclose(stdin); fclose(stdout);
return 0;
}

BZOJ 1067 降雨量的更多相关文章

  1. BZOJ 1067 降雨量(RMQ-ST+有毒的分类讨论)

    1067: [SCOI2007]降雨量 Time Limit: 1 Sec  Memory Limit: 162 MB Submit: 4399  Solved: 1182 [Submit][Stat ...

  2. bzoj 1067: [SCOI2007]降雨量

    题目链接: bzoj 1067: [SCOI2007]降雨量 题解: 很简单的一道题,但代码里有许多细节需要注意,切容易出错,调了三个小时OTZ 做一个st表维护区间最大值就 在获得年份在序列中的po ...

  3. bzoj 1067: [SCOI2007]降雨量 模擬

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

  4. BZOJ 1067:[SCOI2007]降雨量(RMQ+思维)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1067 题意:…… 思路:首先我们开一个数组记录年份,一个记录降雨量,因为年份是按升序排列的,所以我们 ...

  5. 【BZOJ 1067】 [SCOI2007]降雨量

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

  6. bzoj 1067: [SCOI2007]降雨量 (离散化+线段树)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1067 思路: 毒瘤题,写的自闭,改了一晚上,注意要理清题目的逻辑 x小于等于y,x,y之间的 ...

  7. 降雨量 BZOJ 1067

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

  8. 洛谷 2471 BZOJ 1067 [SCOI2007]降雨量

    [题解] 用线段树维护区间最大值(因为没有修改,St表也可以),然后由于x,y可能是降雨量未知的年份,需要进行分类讨论. #include<cstdio> #include<algo ...

  9. BZOJ 1067 & Interval_Tree

    1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 3099 Solved: 800 Description 我们常常 ...

随机推荐

  1. mysql 主从同步配置

    1  环境 mac air 主机做 主库,使用的是XAMPP自带的mysql 版本为 5.6.21, for osx10.6 (x86_64) 虚拟机mysql 做从库  版本为 5.5.38, fo ...

  2. (转)Google Fonts 的介绍与使用

    转载自“前端笔记”  http://www.cnblogs.com/milly/archive/2013/05/10/google-fonts.html Google Fonts 是什么?(以下翻译为 ...

  3. Node.js异步处理CPU密集型任务

    Node.js异步处理CPU密集型任务 Node.js擅长数据密集型实时(data-intensive real-time)交互的应用场景.然而数据密集型实时应用程序并非仅仅有I/O密集型任务,当碰到 ...

  4. [AngularJS + Webpack] ES6 with BabelJS

    Install: npm install --save-dev babel-loader webpack.config.js: Add module, tell webpack to find all ...

  5. RGB的三维模型与渐变色-颜色系列之一

    一.前言 以下与颜色相关的日志记录了俺学习颜色的有关容,限于编写时的水平,难免存在缺点与错误,希望得到朋友.同行和前辈的指教,非常感谢.1.  RGB的三维模型与渐变色-颜色系列之一2.  <颜 ...

  6. MySQL 一致性读 深入研究 digdeep博客学习

    http://www.cnblogs.com/digdeep/p/4947694.html 一致性读,又称为快照读.使用的是MVCC机制读取undo中的已经提交的数据.所以它的读取是非阻塞的. 相关文 ...

  7. Java基础知识强化之集合框架笔记27:ArrayList集合练习之去除ArrayList集合中的重复字符串元素

    1. 去除ArrayList集合中的重复字符串元素(字符串内容相同) 分析: (1)创建集合对象 (2)添加多个字符串元素(包含重复的) (3)创建新的集合 (4)遍历旧集合,获取得到每一个元素 (5 ...

  8. Android Studio学习随笔-UI线程阻塞以及优化

    我们在使用手机的时候,经常会遇到一个问题:先是卡死,然后跳出该程序无响应,是否关闭的提示(当然有可能是我们手机性能太差=.=)这是因为线程的阻塞引起的,在这里我讲述一下UI线程,一般处理程序会在UI线 ...

  9. SQL Server DBA工作内容详解

    在Microsoft SQL Server 2008系统中,数据库管理员(Database Administration,简称为DBA)是最重要的角色.DBA的工作目标就是确保Microsoft SQ ...

  10. 自己写的demo。List<HashMap<String,Object>>=new ArrayList<HashMap<String,Object>>

    package com.pb.collection; import java.util.ArrayList; import java.util.HashMap; import java.util.It ...