BZOJ 1067 & Interval_Tree
1067: [SCOI2007]降雨量
Time Limit: 1 Sec Memory Limit: 162 MB
Submit: 3099 Solved: 800
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
6
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
false
true
false
maybe
false
HINT
100%的数据满足:1<=n<=50000, 1<=m<=10000, -10^9<=yi<=10^9, 1<=ri<=10^9
SOL
裸的线段树,在离散化之后对于每个询问x,y我们在x后查询最大值判断位置、值是否相等即可。(我难得地非常...细心地判断了位置...就没有看到一个人跟我这么写传一个struct的...然而我tm就是wa了有什么办法...
对于maybe的判断,我用一个bool判断当年与上一年的信息是否是相连的,在线段树中用&维护与查询即可。(然而我tm就是wa了有什么办法...
对拍了好多次,有许多数据黄学长都是错的...然而他就是a了有什么办法(难道是我对题意的理解有问题QAQ...
code
虽然没有a掉...但我觉得我写得已经很...perfect了...
/*==========================================================================
# Last modified: 2016-02-08 22:15
# Filename: 1067.cpp
# Description:
==========================================================================*/
#define me AcrossTheSky
#include <cstdio>
#include <cmath>
#include <ctime>
#include <string>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#include <set>
#include <map>
#include <stack>
#include <queue>
#include <vector>
#define lowbit(x) (x)&(-x)
#define INF 1070000000
#define FOR(i,a,b) for((i)=(a);(i)<=(b);(i)++)
#define FORP(i,a,b) for(int i=(a);i<=(b);i++)
#define FORM(i,a,b) for(int i=(a);i>=(b);i--)
#define ls(a,b) (((a)+(b)) << 1)
#define rs(a,b) (((a)+(b)) >> 1)
#define maxn 500005
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
/*==================split line==================*/
struct Infor{
int maxx,pos;
bool mark;
};
int v[maxn*4];
bool mark[maxn*4];
int pos[maxn*4],rain[maxn],year[maxn];
int L,R;
bool bj[maxn];
map<int,int>M;
void build_tree(int node,int l,int r){
if (l==r){
v[node]=rain[l];
mark[node]=bj[l];
pos[node]=l;
return;
}
int mid=rs(l,r),lc=ls(node,0),rc=lc|1;
build_tree(lc,l,mid); build_tree(rc,mid+1,r);
v[node]=max(v[lc],v[rc]);
if (v[lc]>=v[rc]) pos[node]=pos[lc]; else pos[node]=pos[rc];
mark[node]=mark[lc]&mark[rc];
}
Infor query(int node,int l,int r){
if (L<=l && r<=R){
Infor x;
x.maxx=v[node];
x.mark=mark[node];
x.pos=pos[node];
return x;
}
int mid=rs(l,r),lc=ls(node,0),rc=lc|1;
Infor ans; ans.maxx=-INF; ans.mark=true;
if (L<=mid) ans=query(lc,l,mid);
if (R>mid){
Infor t=query(rc,mid+1,r);
if (t.maxx>ans.maxx) ans.maxx=t.maxx,ans.pos=t.pos,ans.mark&=t.mark;
}
return ans;
}
int main(){
freopen("a.in","r",stdin);
freopen("tmp.out","w",stdout);
int n; cin >> n;
memset(mark,true,sizeof(mark));
memset(bj,true,sizeof(bj));
FORP(i,1,n){
scanf("%d%d",&year[i],&rain[i]);
if (i!=1 && year[i]!=year[i-1]+1) bj[i]=false;
M[year[i]]=i;
}
//FORP(i,1,n) printf("%d ",M[year[i]]);
build_tree(1,1,n);
int m; cin >> m;
FORP(i,1,m){
scanf("%d%d",&L,&R);
L=M[L]; R=M[R];
//if (rain[R]>rain[L]) {printf("false\n"); continue;}
L++;
Infor x=query(1,1,n);
if (x.maxx!=rain[R] || x.pos!=R) {printf("false\n"); continue;}
if (x.maxx==rain[R] && x.pos==R && !x.mark) {
printf("maybe\n"); continue;
}
else printf("true\n");
}
}
BZOJ 1067 & Interval_Tree的更多相关文章
- bzoj 1067: [SCOI2007]降雨量
题目链接: bzoj 1067: [SCOI2007]降雨量 题解: 很简单的一道题,但代码里有许多细节需要注意,切容易出错,调了三个小时OTZ 做一个st表维护区间最大值就 在获得年份在序列中的po ...
- BZOJ 1067 降雨量(RMQ-ST+有毒的分类讨论)
1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 4399 Solved: 1182 [Submit][Stat ...
- bzoj 1067: [SCOI2007]降雨量 模擬
1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2010 Solved: 503[Submit][Status] ...
- BZOJ 1067 降雨量
Description 我们常常会说这样的话:"\(X\)年是自\(Y\)年以来降雨量最多的".它的含义是\(X\)年的降雨量不超过\(Y\)年,且对于任意\(Y<Z< ...
- bzoj 1067: [SCOI2007]降雨量 (离散化+线段树)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1067 思路: 毒瘤题,写的自闭,改了一晚上,注意要理清题目的逻辑 x小于等于y,x,y之间的 ...
- BZOJ 1067:[SCOI2007]降雨量(RMQ+思维)
http://www.lydsy.com/JudgeOnline/problem.php?id=1067 题意:…… 思路:首先我们开一个数组记录年份,一个记录降雨量,因为年份是按升序排列的,所以我们 ...
- 【BZOJ 1067】 [SCOI2007]降雨量
Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X年.例如2002,2003,2 ...
- bzoj 1067 分情况讨论
这道题考察人的严谨,各种情况分类讨论. #include <cstdio> #include <algorithm> #include <map> #define ...
- bzoj 1067 特判
这道题的大题思路就是模拟 假设给定的年份是x,y,首先分为4个大的情况,分别是 x的信息已知,y的信息已知 x的信息已知,y的信息未知 x的信息未知,y的情况已知 x的信息未知,y的情况未知 然后对于 ...
随机推荐
- KMP算法精髓
这个算法的做法就是在部分匹配的时候,常规想法是向后移动一位,但是KMP想法是向后移动n位(n=m-L). 注释:这里m表示已经匹配了的字符的个数,L表示已经匹配了的那些字符组成的这个字符串的前缀和后缀 ...
- total commander相关设置
一. 中文语言包 在官方网站上提供有简体中文语言包,下面的说明以此为准.下载的语言包放至Total Commander安装目录下的Language子目录中.从菜单“Configuration”→“Op ...
- 修改setup.py的源
方法一: 修改文件 ~/.pydistutils.cfg为: [easy_install] index_url = http://pypi.douban.com/simple 方法二: 直接在setu ...
- 夏令时 DST (Daylight Saving Time) java中的夏令时【转】
1916年,德国首先实行夏令时,英国因为怕德国会从中得到更大的效益,因此紧跟着也采取了夏令时 1986年至1991年,中华人民共和国在全国范围实行了六年夏令时 サマータイム 夏時間(日本现在没有实行夏 ...
- MQTT——安装、测试
MQTT学习笔记——MQTT协议体验 Mosquitto安装和使用 http://blog.csdn.net/xukai871105/article/details/39252653 ...
- maven项目 Java compiler level does not match the version of the installed Java project facet
因工作的关系,Eclipse开发的Java项目拷来拷去,有时候会报一个很奇怪的错误.明明源码一模一样,为什么项目复制到另一台机器上,就会报“java compiler level does not m ...
- 【转】Apache Solr 访问权限控制
本文转自:http://www.cnblogs.com/ibook360/archive/2011/11/07/2239247.html 在Tomcat6增加 Solr的访问权限方法如下: 编辑tom ...
- iOS 图片拉伸的解释
以前对于ios的图片拉伸参数一直不太理解,终于看到一篇好文章,转载一下,原文地址:http://blog.csdn.net/q199109106q/article/details/8615661 主要 ...
- java将白色背景图片转换成无色
package com.cxf.dao; import java.awt.Graphics2D; import java.awt.Image; import java.awt.image.Buffer ...
- [Android UI] ProgressBar自定义
转载自:http://gundumw100.iteye.com/blog/1289348 1: 在JAVA代码中 在java代码中 ProgressBar 继承自View, 在android ...