http://www.lydsy.com/JudgeOnline/problem.php?id=1067

题意:……

思路:首先我们开一个数组记录年份,一个记录降雨量,因为年份是按升序排列的,所以我们在每个询问找下标的时候可以二分搜索,然后对于每个询问我们是要寻找区间的最大值,因此我们可以使用ST表来做。比较麻烦的是判断三种答案的情况,做了一个下午。假设询问输入的是X和Y(X < Y)接下来分为四种情况:

1、X是已知,Y是已知。那么这是最容易想到的情况。

1-1、如果在[X+1,Y-1]区间中存在大于等于Y的降雨量,或者Y的降雨量大于X的降雨量,那么就输出false。

1-2、否则如果[X+1,Y-1]中存在未知年份,那么就输出maybe。

1-3、否则输出true。

2、X是已知,Y是未知。

2-1、如果在[X+1,Y]区间中存在大于等于X的降雨量,那么输出false。

2-2、否则输出maybe。

这里要注意如果X+1 > Y的情况,那么肯定是输出maybe的。要特判一下。(坑了好久)

3、X是未知,Y是已知。

3-1、如果在[X,Y-1]区间中存在大于等于Y的降雨量,那么输出false。

3-2、否则输出maybe。

4、X是未知,Y是未知。

4-1、直接输出maybe。

这里lower_bound()返回的是大于等于x的下标,upper_bound() - 1返回的是小于等于x的下标。

判断存在不存在就直接是二分后的下标和本身是不是相等的,而不用用到map这样的数据结构判断。

 #include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <iostream>
using namespace std;
#define N 50010
#define INF 0x3f3f3f3f int n, year[N], fall[N], dp[N][]; void RMQ_Init() {
for(int i = ; i <= n; i++) dp[i][] = fall[i];
int ed = (int)(log(n) / log(2.0));
for(int j = ; j <= ed; j++)
for(int i = ; i + ( << j) - <= n; i++)
dp[i][j] = max(dp[i][j-], dp[i+(<<(j-))][j-]);
} int RMQ_Query(int l, int r) {
if(l > r) return -INF; // !!!!!
int ed = (int)(log(r - l + 1.0) / log(2.0));
return max(dp[l][ed], dp[r-(<<ed)+][ed]);
} int main() {
int q;
while(~scanf("%d", &n)) {
for(int i = ; i <= n; i++) scanf("%d%d", &year[i], &fall[i]);
RMQ_Init();
scanf("%d", &q);
while(q--) {
int l, r; scanf("%d%d", &l, &r);
if(l > r) { puts("false"); continue; }
int lid = lower_bound(year + , year + + n, l) - year;
int rid = upper_bound(year + , year + + n, r) - year - ;
int ans, res;
if(year[lid] != l) {
ans = RMQ_Query(lid, rid - );
if(year[rid] != r) puts("maybe");
else if(ans >= fall[rid]) puts("false");
else puts("maybe");
} else if(year[rid] != r) {
ans = RMQ_Query(lid + , rid);
if(ans >= fall[lid]) puts("false");
else puts("maybe");
} else {
ans = RMQ_Query(lid + , rid - );
if(fall[rid] <= ans || fall[lid] < fall[rid]) puts("false");
else if(rid - lid != year[rid] - year[lid]) puts("maybe");
else puts("true");
}
}
}
return ;
} /*
2
2000 4000
2005 4500
1
2005 2010 maybe
*/

BZOJ 1067:[SCOI2007]降雨量(RMQ+思维)的更多相关文章

  1. bzoj 1067: [SCOI2007]降雨量

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

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

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

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

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

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

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

  5. 1067: [SCOI2007]降雨量

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

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

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

  7. BZOJ1067 [SCOI2007]降雨量 RMQ???

    求救!!!神犇帮我瞅瞅呗...未完...调了2个半小时线段树,没调出来,大家帮帮我啊!!! 小詹用st表写. 我的思路就是把中间空着的年份设为无限,然后一点点特判就行了...然而没出来... [SCO ...

  8. 【BZOJ】1067: [SCOI2007]降雨量(rmq+变态题)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1067 好不爽,弄了一个晚上. 好不爽. 还是照着别人程序拍着看的!!! 噗 这题很变态. 首先,我没 ...

  9. 1067: [SCOI2007]降雨量 - BZOJ

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

  10. 洛谷P2471 [SCOI2007] 降雨量 [RMQ,模拟]

    题目传送门 降雨量 题目背景 07四川省选 题目描述 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X ...

随机推荐

  1. 在Keystone V3基础上改进的分布式认证体系

    目标 使用java实现keystone v3相关功能与概念: api client authentication service discovery distributed multi-tenant ...

  2. 【msdn wpf forum翻译】TextBlock等类型的默认样式(implicit style)为何有时不起作用?

    原文:[msdn wpf forum翻译]TextBlock等类型的默认样式(implicit style)为何有时不起作用? 原文链接:http://social.msdn.microsoft.co ...

  3. GIS基础软件及操作(二)

    原文 GIS基础软件及操作(二) 练习二.管理地理空间数据库 1.利用ArcCatalog 管理地理空间数据库 2.在ArcMap中编辑属性数据 第1步 启动 ArcCatalog 打开一个地理数据库 ...

  4. C# SQL数据库的访问类

    /// <summary> /// SQL数据库的访问类 /// </summary> public class SQLHelper { /// <summary> ...

  5. PowerDesigner逆向工程导入MYSQL数据库总结(不容易,感谢前者们)

    原文:PowerDesigner逆向工程导入MYSQL数据库总结(不容易,感谢前者们) 参考来源: http://blog.csdn.net/chamtianjiao/article/details/ ...

  6. docker启动命令,docker重启命令,docker关闭命令

    启动        systemctl start docker 守护进程重启   sudo systemctl daemon-reload 重启docker服务   systemctl restar ...

  7. delphi资源文件制作及使用详解

    一.引子:现在的Windows应用程序几乎都使用图标.图片.光标.声音等,我们称它们为资源(Resource).最简单的使用资源的办法是把这些资源的源文件打入软件包,以方便程序需要的时候调用.资源是程 ...

  8. SharePoint Add-in Model 介绍 - 引文(先导篇)

    1. SharePoint 平台 如果你已经很熟悉 SharePoint 平台,可跳过本章节. 1.1 SharePoint 是什么 在介绍 Add-in Model 之前,简要提一下 SharePo ...

  9. 解决C/C++程序执行一闪而过的方法(使用getchar,或者cin.get,不推荐system(“pause”))

    简述 在VS编写控制台程序的时候,包括使用其他IDE(Visual C++)编写C/C++程序,经常会看到程序的执行结果一闪而过,要解决这个问题,可以在代码的最后加上system(“pause”).g ...

  10. ASP.NET 5 (vNext) 牛刀小試:自帶 DI 容器

    小引 在 ASP.NET 5(vNext)之前,亦即 MVC 4/5.Web API 2 的时代,MVC 与 Web API 框架彼此有非常相似的设计,却是以不同的代码来实现.现在,ASP.NET 5 ...