Luogu P2471

啊啊啊啊这真是一道史上最毒瘤的题目!!!!!

题意就是给出n个年份的降雨量

询问:“自从\(y\)年以来\(x\)年的降雨量最大”的正确性。

显然有多种情况需要考虑,那么就需要通过分类讨论理清程序的逻辑了。

对于“自从\(y\)年以来\(x\)年的降雨量最大”这样一句话,可以转化成如下条件:

\(rain[x]<=rain[y]且\forall a \in [y+1,x-1]有rain[a]<rain[x]\)

经过这样的转化,我们就可以对各种情况进行分类讨论了。

定义:\(query(x,y)\)等于\(rain[x...y]\)的最大值

\[ ①rain[y]未知,rain[x]已知的情况:若此时query(y+1,x-1)>=rain[x]则导出false,反之则导出maybe\\
②rain[x]未知,rain[y]已知:若此时query(y+1,x-1)>=rain[y]则导出false,反之则导出maybe\\
③rain[x]、rain[y]均未知:则导出maybe\\
④两者皆已知:rain[x]>rain[y]导出false;query(y+1,x-1)>=rain[x]导出false\\
若以上两个条件均不符合,则不可能再导出false\\
此时再判断:若\exists a \in [y+1,x-1] 有rain[a]未知,则导出maybe\\
以上所有情况皆不符合则导出true
\]

那么剩下的事情就是把这个东西写成代码了。

Query函数可以用线段树或者st表实现。

如果使用线段树,请记住开4倍空间。

否则将像我一样疯狂WA50。(血的教训)

#include<cstdio>
#include<algorithm>
#define lson root<<1
#define rson root<<1|1
#define mid ((l+r)>>1)
using namespace std;
int tree[4*50005],rain[50005],year[50005],n,m,x,y;
void push_up(int root)
{
tree[root]=max(tree[lson],tree[rson]);
}
void build(int root,int l,int r)
{
if (l==r)
{
tree[root]=rain[l];
return ;
}
build(lson,l,mid);
build(rson,mid+1,r);
push_up(root);
}
int query_max(int root,int l,int r,int al,int ar)
{
if (al<=l&&r<=ar) return tree[root];
if (l>ar||al>r) return 0;
int ret=0;
ret=max(ret,query_max(lson,l,mid,al,ar));
ret=max(ret,query_max(rson,mid+1,r,al,ar));
return ret;
}
int main()
{
scanf("%d",&n);
for (int i=1;i<=n;i++) scanf("%d%d",&year[i],&rain[i]);
build(1,1,n);
scanf("%d",&m);
for (int i=1;i<=m;i++)
{
scanf("%d%d",&y,&x);
if (x<=y)
{
printf("false\n");
continue;
}
int locx=lower_bound(year+1,year+n+1,x)-year;
int locy=lower_bound(year+1,year+n+1,y)-year;
if (x==y+1)//其实不需要特判,只要在query函数中加一个判断,如果区间不合法则返回0即可。
{
if (year[locx]!=x) printf("maybe\n");
else if (year[locy]!=y) printf("maybe\n");
else if (rain[locx]<=rain[locy]) printf("true\n");
else printf("false\n");
continue;
}
else
{
int lx=year[locx],ly=year[locy];
if (lx==x&&ly!=y)
{
if (query_max(1,1,n,locy,locx-1)>=rain[locx]) printf("false\n");
else printf("maybe\n");
}
if (lx!=x&&ly==y)
{
if (query_max(1,1,n,locy+1,locx-1)>=rain[locy]) printf("false\n");
else printf("maybe\n");
}
if (lx!=x&&ly!=y) printf("maybe\n");
if (lx==x&&ly==y)
{
if (rain[locx]<=rain[locy])
{
if (query_max(1,1,n,locy+1,locx-1)<rain[locx])
{
if (locx-locy==x-y) printf("true\n");
else printf("maybe\n");
}
else printf("false\n");
}
else printf("false\n");
}
}
}
return 0;
}

【Luogu P2471】[SCOI2007]降雨量的更多相关文章

  1. 洛谷P2471 [SCOI2007] 降雨量 [RMQ,模拟]

    题目传送门 降雨量 题目背景 07四川省选 题目描述 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X ...

  2. P2471 [SCOI2007]降雨量

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

  3. BZOJ1067&P2471 [SCOI2007]降雨量[线段树裸题+细节注意]

    dlntqlwsl 很裸的一道线段树题,被硬生生刷成了紫题..可能因为细节问题吧,我也栽了一次WA50分.不过这个隐藏条件真的对本菜鸡来说不易发现啊. 未知的年份连续的就看成一个就好了,把年份都离散化 ...

  4. 洛谷P2471——[SCOI2007]降雨量

    本机AC提交RE…… 传送门:QAQQAQ 题意:自己看 思路:据说这道题用RMQ做很快,但这道题线段树是可以的 线段树维护一段区间最左年,最右年,是否有间隙和区间最大值 这道题分类讨论是一大难点,主 ...

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

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

  6. [BZOJ1067][SCOI2007]降雨量

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

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

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

  8. 1067: [SCOI2007]降雨量

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

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

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

随机推荐

  1. join的使用

    我们还是以这四张表为例:1.left joinselect * from student a left join score b on a.sid=b.sid; 也就是说A中的元素都会显示,没有值的用 ...

  2. Flask解析(一):Local、LocalStak、LocalProxy

    原创作者:flowell,转载请标明出处:https://www.cnblogs.com/flowell/p/local_local_proxy_local_stack.html Local是什么? ...

  3. vue进入新页面,与原页面滚动到相同高度的解决方案

    可以在vue路由新增scrollBehavior,控制跳转页面高度 import Router from 'vue-router' new Router({ scrollBehavior (to, f ...

  4. jupyter notebook启动需要输入密码的问题

    问题描述: 安装完jupyter notebook之后,启动时需要输入密码,如下图所示: 解决方法: 1.启动jupyter notebook 2.在另一个的终端中输入 jupyter noteboo ...

  5. Docker入门详解——安装docker并利用docker搭建lnmp

    首先我们需先安装docker环境,这个比较简单,以centos7为例 docker在centos7上安装需要系统内核版本3.10+,可以通过uname -r查看内核版本号,如果版本不符请自行查阅资料更 ...

  6. Linux常见命令之文件处理命令

    ls命令 ls(选项)(参数) 选项 -a:显示所有档案及目录(ls内定将档案名或目录名称为“.”的视为影藏,不会列出): -A:显示除影藏文件“.”和“..”以外的所有文件列表: -C:多列显示输出 ...

  7. 20190730_图像混合_opencv_python

    今天学习了 图像的混合 教程上的代码很简单,但是绝对运行不出来 教程名称:OpenCV-Python 中文教程 #图像融合 import cv2 import numpy as np import m ...

  8. MongoDB自学------(1)MongoDB4.0安装

    一.环境 操作系统 安装包 安装方式 Ubuntu18.04 mongodb4.0 apt安装 Ubuntu18.04 mongodb4.0 docker安装 二.apt安装 sudo apt-key ...

  9. python语言线程标准库threading.local源码解读

    本段源码可以学习的地方: 1. 考虑到效率问题,可以通过上下文的机制,在属性被访问的时候临时构建: 2. 可以重写一些魔术方法,比如 __new__ 方法,在调用 object.__new__(cls ...

  10. haproxy+keepalived练习

    小的网站结构 说明:如果部署在云上,比如阿里云上,不需要自己部署keepalived,直接买阿里云的slb即可,slb然后分发流量到两台haproxy机器 一.先部署两个web服务器 编译安装ngin ...