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. 汉顺平html5课程分享:6小时制作经典的坦克大战!

    记起自己去年參加的一次面试,在做过Java多年的面试官面前发挥的并不好,但他一听说我会html5,立刻眼睛发亮.无论不顾的想要和我签约.. .所以.如今为工作犯愁的朋友们,学好html5,绝对会为你找 ...

  2. IdentityServer学习目录

    IdentityServer IdentityServer的基本概念与特性 IdentityServer流程图与相关术语 最简单的IdentityServer实现 最简单的IdentityServer ...

  3. apache卸载

    windows下apache如何完整卸载? 原创 2014年08月14日 21:30:38 13960 1.运行services.msc,在服务中停止 apache 服务. 2.运行命令行程序,输入 ...

  4. wpf中防止界面卡死的写法

    原文:wpf中防止界面卡死的写法 ); this.Dispatcher.BeginInvoke(new Action(() => { this.button1.Content = "计 ...

  5. Z-Order

    The z-order of a window indicates the window's position in a stack of overlapping windows. This wind ...

  6. UAP开发错误之The given System.Uri cannot be converted into a Windows.Foundation.Uri(windows phone背景更换)

    今天博主在开发一款windows phone应用时,希望实现app背景的更换,思路很简单.使用ApplicationDataContainer容器存储我的图片路径,每次载入应用时读取这个路径以决定我用 ...

  7. WebBrowser中获得脚本中的变量值

    //项目中添加Micrsoft.mshtml引用 --c:/temp/temp.htm-- <html> <script language="JavaScript" ...

  8. Angular4初学

    [1].在学习Angular4之前,首先要了解一些typescript的知识. 以下是我的总结:https://gitee.com/FangXiaoQi123/angularJSCeShi/blob/ ...

  9. Java的String类字符串的拆分

    在java编程中,有时候我们需要把一个字符串按照某个特定字符.字母等作为截点分割这个字符串, 这样我们就可以使用这个字符串的一部分或者把所有截取的内容保存到数组里等操作. public class S ...

  10. SYN591-B型 转速表

       SYN591-B型 转速表 光电转速表数显转速表智能转速表使用说明视频链接: http://www.syn029.com/h-pd-249-0_310_44_-1.html 请将此链接复制到浏览 ...