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 ...
随机推荐
- UVE开发环境搭建及项目启动
1.IDE安装visual studio code ,略: 2.node安装(node-v10.5.0-win-x64.zip),解压即可: 3.配置node环境变量,cmd 输入node -v.np ...
- hibernate关于多对多注解配置
Game实体类配置关系 @Entity @Table(name = "game") public class Game { @Id @GeneratedValue private ...
- git 专题
$ git pull origin test // git pull合并代码的时候,若发生冲突,会处于merging状态,检查代码,发现自己的分支低于主分支,这个时候想撤销merge // 撤销mer ...
- delphi文件操作(比较全)
Delphi中默认有input和output两个文件变量,使用可以不用定义,直接使用. 但: input:只读.output:只写.用时注意以免引起异常. 文件是由文件名标识的一组数据的集合,文件通常 ...
- Oracle VM VirtualBox ubuntu 共享文件设置
1.创建共享文件 2.在本机上选择共享文件路径,虚拟机设置共享文件名称,注意这里不能选择自动挂载 3. 虚拟机新建文件夹挂载共享文件 sudo mkdir /mnt/sharedsudo mount ...
- Win8 Metro(C#)数字图像处理--2.61哈哈镜效果
原文:Win8 Metro(C#)数字图像处理--2.61哈哈镜效果 [函数名称] 哈哈镜效果函数 WriteableBitmap DistortingMirrorProcess(Writea ...
- InnoSetup提升系统管理员权限(通过破解方式修改?)
PrivilegesRequired=admin 1 2 3 4 5 找到```INNO```安装目录下的```SetupLdr.e32```文件(其实就是一个exe程序),将程序中的```Man ...
- JAVA 与 PHP 的不同和相同
Java语言与PHP语言因为都可以做web应用开发,所以总有入门学习这2种语言的入门者会问Java和PHP哪一个好.讨论语言的好坏是一件不太明智的事情,我认为只能去说那一种编程语言更加适合干什么,人与 ...
- xe5 firemonkey关闭应用程序
在FMX中,由Activity替代了Form的概念,虽然TForm类仍然存在,但MainForm通过关闭函数无法结束程序,使用Application.Terminate均无效,调整为: uses ...
- ASP.NET Web API 直到我膝盖中了一箭【1】基础篇
蓦然回首,那些年,我竟然一直很二. 小时候,读武侠小说的时候,看到那些猪脚,常常会产生一种代入感,幻想自己也会遭遇某种奇遇,遇到悬崖跳下去是不是有本“武林秘笈”在等着?长大以后也是一样,多少人梦着醒着 ...