BZOJ 1067:[SCOI2007]降雨量(RMQ+思维)
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+思维)的更多相关文章
- bzoj 1067: [SCOI2007]降雨量
题目链接: bzoj 1067: [SCOI2007]降雨量 题解: 很简单的一道题,但代码里有许多细节需要注意,切容易出错,调了三个小时OTZ 做一个st表维护区间最大值就 在获得年份在序列中的po ...
- bzoj 1067: [SCOI2007]降雨量 模擬
1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2010 Solved: 503[Submit][Status] ...
- bzoj 1067: [SCOI2007]降雨量 (离散化+线段树)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1067 思路: 毒瘤题,写的自闭,改了一晚上,注意要理清题目的逻辑 x小于等于y,x,y之间的 ...
- 洛谷 2471 BZOJ 1067 [SCOI2007]降雨量
[题解] 用线段树维护区间最大值(因为没有修改,St表也可以),然后由于x,y可能是降雨量未知的年份,需要进行分类讨论. #include<cstdio> #include<algo ...
- 1067: [SCOI2007]降雨量
1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2148 Solved: 554[Submit][Status] ...
- 【BZOJ1067】[SCOI2007]降雨量 RMQ+特判
[BZOJ1067][SCOI2007]降雨量 Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年 ...
- BZOJ1067 [SCOI2007]降雨量 RMQ???
求救!!!神犇帮我瞅瞅呗...未完...调了2个半小时线段树,没调出来,大家帮帮我啊!!! 小詹用st表写. 我的思路就是把中间空着的年份设为无限,然后一点点特判就行了...然而没出来... [SCO ...
- 【BZOJ】1067: [SCOI2007]降雨量(rmq+变态题)
http://www.lydsy.com/JudgeOnline/problem.php?id=1067 好不爽,弄了一个晚上. 好不爽. 还是照着别人程序拍着看的!!! 噗 这题很变态. 首先,我没 ...
- 1067: [SCOI2007]降雨量 - BZOJ
Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X年.例如2002,2003,2 ...
- 洛谷P2471 [SCOI2007] 降雨量 [RMQ,模拟]
题目传送门 降雨量 题目背景 07四川省选 题目描述 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X ...
随机推荐
- SourceTree 免注册使用
sourcetree安装的时候,需要注册.但是这个注册需要FQ,所以我们需要绕过注册 1. 找到目录:C:\Users\用户\AppData\Local\Atlassian\SourceTree 2. ...
- EF相关报错
EF7无法找寻依赖问题解决方案 现象:使用EF7的过程中,任何"dnx . XXX"的都会报错,提示"cannot resolve dependencies for ta ...
- 读BeautifulSoup官方文档之与bs有关的对象和属性(1)
自从10号又是5天没更, 是, 我再一次断更... 原因是朋友在搞python, 老问我问题, 我python也是很久没碰了, 于是为了解决他的问题, 我只能重新开始研究python, 为了快速找回感 ...
- windows下,Qt Creator 中javascript调试器安装并使用
最开始使用Qt Creator时,想使用断点来调试javascript代码.但在按下debug键后,却提示调试器未配置,让我比较郁闷. 好了,郁闷的是说了,咱们来说说高兴的.要Qt Creator调试 ...
- ADB 基础命令使用
1.adb shell(>=2个设备显示:error: more than one device/emulator,仅连接一个设备可用) adb -d shell 只运行在真实设备中 adb - ...
- 未在本地计算机上注册“microsoft.ACE.oledb.12.0” 解决方法
今日写一个浏览Excel文件的代码,忽然发现提示如下错误,表示很惊讶,因为我的另外一台电脑不会,但是这台就包这个异常. 解决方法: 去http://download.microsoft.com/dow ...
- 零元学Expression Blend 4 Chapter 22 以实作案例学习Frame及HyperlinkButton
原文:零元学Expression Blend 4 Chapter 22 以实作案例学习Frame及HyperlinkButton 本章将教大家如何以实作善用Blend4的内建功能-「Frame」以及「 ...
- Upgrade a Non-CDB To a PDB on CDB
.Stop the cluster database and start database on one node with read noly [oracle@raca1 admin]$ srvct ...
- UWP入门(四)--设置控件样式
原文:UWP入门(四)--设置控件样式 官方定义:可以使用 XAML 框架通过多种方式自定义应用的外观. 通过样式可以设置控件属性,并重复使用这些设置,以便保持多个控件具有一致的外观. 可分享至不同e ...
- 配置QtCreator+CDB远程调试环境(用到了符号表) good
相关环境信息:开发机Win7 x64.远程机器WinXP.调试器是CDB.Qt版本5.2.1 一.部署远程机器环境 我这里用的是虚拟机(Windows XP),根据你要调试的程序选择安装不同架构的Wi ...