【BZOJ】【1067】 【SCOI2007】降雨量
思路题
玛雅,这分类讨论快讨论地疯了……
从huzecong神的题解那里得到的灵感……
首先考虑最好确定的情况:为true的时候,此时必须同时满足
1.x和y这两年的降雨量已知,且rain[x]<=rain[y]
2.中间每一年的降雨量都已知,且降雨量的最大值小于rain[x]
然后我们可以考虑一下为false的情况:(这两个条件满足其一即可)
1.x和y这两年的降雨量已知,且rain[x]>rain[y]
2.x和y这两年的降雨量只知其中之一,且中间这些年(已知的部分)最大的降雨量大于这个已知的x或y年的降雨量
剩下的情况直接输出maybe
但是如果你这么写你会发现你RE了= =,为什么呢?因为在x和y这两年的降雨量只知其中之一时,“中间年份“已知的可能一个也没有,也就是说我在进行中间这些年的降雨量的最大值的查询时会直接爆炸(我是用线段树来查询的)……所以需要在判false的第二种情况之前加上这一条:
如果x和y中间没有其他年份,则输出maybe
然后我才AC掉……
- /**************************************************************
- Problem: 1067
- User: Tunix
- Language: C++
- Result: Accepted
- Time:164 ms
- Memory:3616 kb
- ****************************************************************/
- //BZOJ 1067
- #include<vector>
- #include<cstdio>
- #include<cstring>
- #include<cstdlib>
- #include<iostream>
- #include<algorithm>
- #define rep(i,n) for(int i=0;i<n;++i)
- #define F(i,j,n) for(int i=j;i<=n;++i)
- #define D(i,j,n) for(int i=j;i>=n;--i)
- #define pb push_back
- using namespace std;
- inline int getint(){
- int v=,sign=; char ch=getchar();
- while(ch<''||ch>''){ if (ch=='-') sign=-; ch=getchar();}
- while(ch>=''&&ch<=''){ v=v*+ch-''; ch=getchar();}
- return v*sign;
- }
- const int N=1e5+,INF=~0u>>;
- typedef long long LL;
- /******************tamplate*********************/
- int n,m,t[N<<],year[N],rain[N];
- #define L (o<<1)
- #define R (o<<1|1)
- #define mid (l+r>>1)
- void build(int o,int l,int r){
- if (l==r) t[o]=rain[l];
- else{
- build(L,l,mid);
- build(R,mid+,r);
- t[o]=max(t[L],t[R]);
- }
- }
- int ql,qr;
- int query(int o,int l,int r){
- if (ql<=l && qr>=r) return t[o];
- else{
- int ans=;
- if (ql<=mid) ans=max(ans,query(L,l,mid));
- if (qr>mid) ans=max(ans,query(R,mid+,r));
- return ans;
- }
- }
- int main(){
- #ifndef ONLINE_JUDGE
- freopen("1067.in","r",stdin);
- freopen("1067.out","w",stdout);
- #endif
- n=getint();
- F(i,,n) year[i]=getint(),rain[i]=getint();
- build(,,n);
- m=getint();
- int x,y,t1,t2;
- F(i,,m){
- x=getint(); y=getint();
- t1=upper_bound(year+,year+n+,x)-year;
- t2=lower_bound(year+,year+n+,y)-year;
- if (year[t2]==y && year[t1-]==x && t1!=n+ && t2!=n+ &&
- t2-t1==y-x- && rain[t2]<=rain[t1-]){
- ql=t1; qr=t2-;
- if (query(,,n)<rain[t2]) {puts("true");continue;}
- else {puts("false");continue;}
- }
- if(year[t2]==y && year[t1-]==x && rain[t2]>rain[t1-])
- {puts("false");continue;}
- if(t2==t1){puts("maybe");continue;}
- if(year[t2]==y && t2!=n+){
- ql=t1; qr=t2-;
- if (query(,,n)>=rain[t2]) {puts("false");continue;}
- }
- if(year[t1-]==x && t1!=n+){
- ql=t1; qr=t2-;
- if (query(,,n)>=rain[t1-]) {puts("false");continue;}
- }
- puts("maybe");
- }
- return ;
- }
1067: [SCOI2007]降雨量
Time Limit: 1 Sec Memory Limit: 162 MB
Submit: 2370 Solved: 613
[Submit][Status][Discuss]
Description
我
们常常会说这样的话:“X年是自Y年以来降雨量最多的”。它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X年。例如
2002,2003,2004和2005年的降雨量分别为4920,5901,2832和3890,则可以说“2005年是自2003年以来最多的”,但
不能说“2005年是自2002年以来最多的”由于有些年份的降雨量未知,有的说法是可能正确也可以不正确的。
Input
输
入仅一行包含一个正整数n,为已知的数据。以下n行每行两个整数yi和ri,为年份和降雨量,按照年份从小到大排列,即yi<yi+1。下一行包含一个正
整数m,为询问的次数。以下m行每行包含两个数Y和X,即询问“X年是自Y年以来降雨量最多的。”这句话是必真、必假还是“有可能”。
Output
对于每一个询问,输出true,false或者maybe。
Sample Input
2002 4920
2003 5901
2004 2832
2005 3890
2007 5609
2008 3024
5
2002 2005
2003 2005
2002 2007
2003 2007
2005 2008
Sample Output
true
false
maybe
false
HINT
100%的数据满足:1<=n<=50000, 1<=m<=10000, -10^9<=yi<=10^9, 1<=ri<=10^9
Source
【BZOJ】【1067】 【SCOI2007】降雨量的更多相关文章
- 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] ...
- 【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 ...
- 1067. [SCOI2007]降雨量【线段树】
Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意 Y<Z<X,Z年的降雨量严格小于X年.例如2002,2003, ...
- BZOJ 1067 降雨量(RMQ-ST+有毒的分类讨论)
1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 4399 Solved: 1182 [Submit][Stat ...
- BZOJ 1067 & Interval_Tree
1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 3099 Solved: 800 Description 我们常常 ...
随机推荐
- js 获取当天23点59分59秒 时间戳 (最简单的方法)
js 获取当天23点59分59秒 时间戳 (最简单的方法) new Date(new Date(new Date().toLocaleDateString()).getTime()+24*60*60* ...
- linux中的虚拟化网络模型及各种模型实现
第一种隔离模型: Guest1和Guest2都为虚拟机. 首先要了解在linux中的虚拟机的网卡都包含前半段和后半段,前半段在虚拟机上,后半段在宿主机上,这里以centos6为例,上图 eth0为Gu ...
- discuz 模拟批量上传附件发帖
discuz 模拟批量上传附件发帖 简介 对于很多用discuz做资源下载站来说,一个个上传附件,发帖是很繁琐的过程.如果需要批量上传附件发帖,就需要去模拟discuz 上传附件的流程. 插件地址 h ...
- 了解Unix进程(1)
今天瞎看 看到一本了解Unix进程 -- 理解UNIX进程 的书 不错,可以看看,使用的ruby语言,第一章讲的是一些基础的知识 1.输出进程号和父进程号: puts Process.pid # 得到 ...
- 等价表达式 (codevs 1107)题解
[问题描述] 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的要求是判断选项中哪些 ...
- asp.net解析请求报文
NameValueCollection myHeader = new NameValueCollection(); int i; string strKey; string result; myHea ...
- 关于fseek和文件"ab+"打开方式的问题
这是在写一个文件的的时候发生的一个错误,代码如下 #include<stdio.h> #include <errno.h> #include <string.h> ...
- STM32F0_新建软件工程详细过程
前言 由于ST公司推出比STM32F1性价比更高的F0芯片,现在市面上F0芯片的占有率也非常高.F0芯片属于M0内核,主频48M(当然,可以超频的,但尽量不要超的太多),资源大小可根据项目需求来选型. ...
- pure css做的pc登陆界面
源码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w ...
- 【Django】Apache上运行多个Django项目
运行单个项目的步骤参考:这里 1 安装环境 操作系统:Ubuntu 12.04 LTS 32 位(安装在VMware虚拟机中) python 版本: Python 2.7.3 Django版本 > ...