【SCOI2007】降雨量
新人求助,降雨量那题本机AC提交WAWAWA……
原题:
我们常常会说这样的话:“X年是自Y年以来降雨量最多的”。它的含义是X年的降雨量不超过Y年,且对于任意
Y<Z<X,Z年的降雨量严格小于X年。例如2002,2003,2004和2005年的降雨量分别为4920,5901,2832和3890,
则可以说“2005年是自2003年以来最多的”,但不能说“2005年是自2002年以来最多的”由于有些年份的降雨量未
知,有的说法是可能正确也可以不正确的。
1<=n<=50000, 1<=m<=10000, -10^9<=yi<=10^9, 1<=ri<=10^9
以前的博客说这题没啥思维难度,难就难在细节讨论
这次写信心爆棚认为老子现在问题处理地多棒,只需转化某些要点的表达方式就可以避免讨论
然后……


行吧,这次是我被练了
代码:
#include<iostream>
#include<cstdio>
using namespace std;
const int oo=;
int n,a[],b[],m;
int v[]; bool u[];
void gtsgmttr(int x,int l,int r){
if(l==r){
v[x]=b[l],u[x]=false;
return ;
}
int md=(l+r)>>;
gtsgmttr(x<<,l,md),gtsgmttr(x<<|,md+,r);
v[x]=max(v[x<<],v[x<<|]);
u[x]=(u[x<<]|u[x<<|]|(a[md]+!=a[md+]));
}
int qrv(int x,int l,int r,int ql,int qr){
if(l==ql && r==qr) return v[x];
int md=(l+r)>>;
if(ql<=md && qr>md)
return max(qrv(x<<,l,md,ql,md),qrv(x<<|,md+,r,md+,qr));
else if(qr<=md) return qrv(x<<,l,md,ql,qr);
else return qrv(x<<|,md+,r,ql,qr);
}
bool qru(int x,int l,int r,int ql,int qr){
if(l==ql && r==qr) return u[x];
int md=(l+r)>>;
if(ql<=md && qr>md)
return (qru(x<<,l,md,ql,md)|qru(x<<|,md+,r,md+,qr)|(a[md]+!=a[md+]));
else if(qr<=md) return qru(x<<,l,md,ql,qr);
else return qru(x<<|,md+,r,ql,qr);
}
int bnrsch(int x){ //如果找不到默认输出左侧的
int l=,r=n,md;
//int l=1,r=n,md;
//如果l初值为1,则若左端点小于最小值,那么实际返回的是右侧的
while(l+<r){
md=(l+r)>>;
(a[md]<x ? l : r)=md;
}
//return (a[l]!=x && a[r]!=x ? -1 : (a[l]==x ? l : r));
return a[r]==x ? r : l;
}
int main(){
freopen("ddd.in","r",stdin);
cin>>n;
for(int i=;i<=n;++i) scanf("%d%d",&a[i],&b[i]);
gtsgmttr(,,n);
cin>>m;
int l,r,x,y;
while(m --> ){
scanf("%d%d",&x,&y);
l=bnrsch(x),r=bnrsch(y);
if(x>=y+) printf("false\n");
//else if(a[r]!=y || a[l]!=x) printf("maybe\n");
if(a[l]!=x && a[r]!=y) printf("maybe\n");
else if(a[l]!=x || a[r]!=y){
//注意如果两个端点只知道一个也是能判必错的
int tmp=(l+<=r-(a[r]==y) ? qrv(,,n,l+,r-(a[r]==y)) : );
if(a[l]!=x ? b[r]<=tmp : b[l]<=tmp) printf("false\n");
else printf("maybe\n");
}
else if(b[r]>b[l]) printf("false\n");
else{
int tmp=(l+<=r- ? qrv(,,n,l+,r-) : );
if(b[r]<=tmp) printf("false\n");
else if(qru(,,n,l,r)) printf("maybe\n");
else printf("true\n");
}
}
return ;
}
【SCOI2007】降雨量的更多相关文章
- [BZOJ1067][SCOI2007]降雨量
[BZOJ1067][SCOI2007]降雨量 试题描述 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意 Y<Z<X,Z年的降雨量严格 ...
- bzoj 1067: [SCOI2007]降雨量 模擬
1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2010 Solved: 503[Submit][Status] ...
- 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年 ...
- bzoj 1067: [SCOI2007]降雨量
题目链接: bzoj 1067: [SCOI2007]降雨量 题解: 很简单的一道题,但代码里有许多细节需要注意,切容易出错,调了三个小时OTZ 做一个st表维护区间最大值就 在获得年份在序列中的po ...
- 【线段树 细节题】bzoj1067: [SCOI2007]降雨量
主要还是细节分析:线段树作为工具 Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小 ...
- BZOJ_1067_[SCOI2007]降雨量_ST表
BZOJ_1067_[SCOI2007]降雨量_ST表 Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意 Y<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 ...
随机推荐
- 向量空间模型(Vector Space Model)
搜索结果排序是搜索引擎最核心的构成部分,很大程度上决定了搜索引擎的质量好坏.虽然搜索引擎在实际结果排序时考虑了上百个相关因子,但最重要的因素还是用户查询与网页内容的相关性.(ps:百度最臭名朝著的“竞 ...
- csu 1898: 复盘拉火车
1898: 复盘拉火车 Submit Page Summary Time Limit: 1 Sec Memory Limit: 128 Mb Submitted: 114 ...
- python 使用 RabbitMQ
一.RabbitMQ消息队列介绍 RabbitMQ是在两个独立得python程序,或其他语言交互时使用. RabbitMQ:erlang语言 开发的. Python中连接RabbitMQ的模块:pik ...
- Vue.js与React的全面对比
Vue与React的对比 Vue.js与React.js从某些反面来说很相似,通过两个框架的学习,有时候对一些用法会有一点思考,为加深学习的思索,特翻阅了两个文档,从以下各方面进行了对比,加深了对这两 ...
- pythn print格式化输出:%s与%d
pythn print格式化输出. %r 用来做 debug 比较好,因为它会显示变量的原始数据(raw data),而其它的符号则是用来向用户显示输出的. 1. 打印字符串 print (" ...
- 使用内存地址点亮LED—跟51单片机一样写代码教学(初步入门)
51单片机点亮一个小灯 #include <rge52.h> sbit LED = P0^ void main(void) { P0 = 0XFE; // 总线操作 sfr P0 0X80 ...
- redis源码解读--内存分配zmalloc
目录 主要函数 void *zmalloc(size_t size) void *zcalloc(size_t size) void zrealloc(void ptr, size_t size) v ...
- (四)XML基础(客户端和服务端发送与接收xml数据)
案例: index.jsp <%@ page language="java" import="java.util.*" pageEncoding=&quo ...
- Go 标准库,常用的包及功能
Go 的标准库 Go语言的标准库覆盖网络.系统.加密.编码.图形等各个方面,可以直接使用标准库的 http 包进行 HTTP 协议的收发处理:网络库基于高性能的操作系统通信模型(Linux 的 epo ...
- Android获取设备唯一码
String uuid = ""; String serial = null; String m_szDevIDShort = "35" + Build.BOA ...