新人求助,降雨量那题本机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】降雨量的更多相关文章

  1. [BZOJ1067][SCOI2007]降雨量

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

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

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

  3. 1067: [SCOI2007]降雨量

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

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

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

  5. bzoj 1067: [SCOI2007]降雨量

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

  6. 【线段树 细节题】bzoj1067: [SCOI2007]降雨量

    主要还是细节分析:线段树作为工具 Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小 ...

  7. BZOJ_1067_[SCOI2007]降雨量_ST表

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

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

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

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

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

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

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

随机推荐

  1. MySQL的注入总结

    0x01 MySQL 5.0以上和MySQL 5.0以下版本的区别 MySQL5.0以上版本存在一个叫information_schema的数据库,它存储着数据库的所有信息,其中保存着关于MySQL服 ...

  2. vue {{}}的用法

    参考链接:https://blog.csdn.net/cofecode/article/details/78666233

  3. 不使用局部变量和for循环或其它循环打印出如m=19,n=2結果为2 4 8 16 16 8 4 2形式的串

    需求:不使用局部变量和for循环或其它循环打印形如:2 4 8 16 16 8 4 2 这样的串 代码MainTest.java package com.szp.study.javase.specia ...

  4. 洛谷 题解 UVA1151 【买还是建 Buy or Build】

    [题意] 平面上有\(n(n<=1000)\)个点,你的任务是让所有n个点联通.为此,你可以新建一些边,费用等于两个端点的欧几里得距离平方.另外还有\(q(q<=8)\)个套餐可以购买,如 ...

  5. springboot集成elk 二:springboot + elk 采集日志

    到logstash-2.0.0\bin下新建文件 logstash.conf input { tcp { mode => "server" host => " ...

  6. 使用 IDEA 创建 maven 项目

    文章目录 第一步 第二步 第三步 目录结构的设置 看下 web.xml 配置文件 第一步 点击 maven : 勾选从模板创建 : 选择 webapp : 第二步 第三步 如果你自己对 maven 进 ...

  7. java中单双引号的区别

    单引号: 单引号包括的是单个字符,表示的是char类型.例如: char  a='1' 双引号: 双引号可以包括0个或者多个字符,表示的是String类型. 例如: String s="ab ...

  8. UOJ208 UOIP十合一(提交答案)

    首先对每张图都去掉自环. 1:给出的就是DAG.答案即为2m. 2.5:显然每个SCC之间互相独立.这两个点都满足SCC中的点很少.于是对每个SCC暴力枚举边集判环,而SCC之间的边显然选不选没有影响 ...

  9. root用户和sudo使用root权限的区别(转)

    百度百科:https://baike.baidu.com/item/sudo/7337623?fr=aladdin sudo指令 功能: 以root的身分执行命令 语法: sudo 其他指令 用户: ...

  10. 怎样使用wordpress模板建站

    这里仅整理一个思路, 日后会详细补充. 1. 首先得下载 wordpress安装包, 上传到服务器上的 /var/www/html, 然后解压. 2. 然后安装apache 并启动, 启动一般是使用: ...