P2471 [SCOI2007]降雨量
Description
我们常常会说这样的话:“X年是自Y年以来降雨量最多的”。它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X年。例如2002,2003,2004和2005年的降雨量分别为4920,5901,2832和3890,则可以说“2005年是自2003年以来最多的”,但不能说“2005年是自2002年以来最多的”由于有些年份的降雨量未知,有的说法是可能正确也可以不正确的。
Solution
抱歉在下实在是读不懂题目.
降雨量:
-3951 1990
-3941 2156
查询
-3951 -3941
应该输出啥?
maybe
或者是false
?????
Code
#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
// #define int long long
struct Node {
int mx, isfull; Node *ls, *rs;
Node(int _ = 0, int __ = 0, Node *_ls = nullptr, Node *_rs = nullptr) :
mx(_), isfull(__), ls(_ls), rs(_rs) { }
void PushUp() {
mx = std:: max(ls ? ls->mx : 0, rs ? rs->mx : 0);
isfull = (ls ? ls->isfull : 0) bitand (rs ? rs->isfull : 0);
}
void init(int p) {
mx = p, isfull = true;
}
void merge(Node o) {
mx = std:: max(mx, o.mx), isfull = isfull bitand o.isfull;
}
};
class Tree {
int n, lim;
Node *root;
#define LS l, mid, node->ls
#define RS mid + 1, r, node->rs
void insert(int l, int r, Node* node, const int& p, const int& k) {
if (l == r) {
return node->init(k);
}
int mid = ((long long)l + r) >> 1ll;
if (p <= mid) {
if (not node->ls) node->ls = new Node();
insert(LS, p, k);
}
if (p > mid) {
if (not node->rs) node->rs = new Node();
insert(RS, p, k);
}
node->PushUp();
}
Node query(int l, int r, Node* node, const int& L, const int& R) {
if (l >= L and r <= R) return *node;
int mid = ((long long)l + r) >> 1ll;
Node res = Node(0, 1);
if (L <= mid) res.merge(node->ls ? query(LS, L, R) : Node(0, 0));
if (R > mid) res.merge(node->rs ? query(RS, L, R) : Node(0, 0));
return res;
}
int query(int l, int r, Node* node, const int& p) {
if (l == r) return node->mx;
int mid = ((long long)l + r) >> 1ll;
if (p <= mid) return node->ls ? query(LS, p) : -1;
if (p > mid) return node->rs ? query(RS, p) : -1;
}
#undef LS
#undef RS
public:
Tree(int _n) : n(_n), root(new Node()), lim(0) {}
void insert(int p, int k) {
// printf("insert: %d %d\n", p, k);
lim = std:: max(lim, p);
return insert(1, n, root, p, k);
}
inline Node query(int l, int r) {
if (l > r) return false;
// printf("query: %d %d\n", l, r);
return query(1, n, root, l, r);
}
int solution(int k, int p) {
int val = query(1, n, root, p);
// printf("val : %d %d\n", p, val);
if (val == -1) return -1;
Node res = query(k + 1, p - 1);
return val < res.mx ? false : (res.isfull ? true : -1);
}
};
const int Delta = 1e8 + 1;
void test();
signed main () {
// test();
int n;
scanf("%lld", &n);
Tree* T = new Tree(1e9 + 1);
for (int i = 0, y, r; i < n; i += 1) {
scanf("%lld%lld", &y, &r);
T->insert(y + Delta, r);
}
int m;
scanf("%lld", &m);
for (int i = 0, y, r; i < m; i += 1) {
scanf("%lld%lld", &y, &r);
int res = T->solution(y + Delta, r + Delta);
printf("%s\n", ~res ? (res ? "true" : "false") : "maybe");
}
return 0;
}
void test() {
freopen("1.in", "r", stdin);
freopen("1.out", "w", stdout);
}
P2471 [SCOI2007]降雨量的更多相关文章
- 洛谷P2471 [SCOI2007] 降雨量 [RMQ,模拟]
题目传送门 降雨量 题目背景 07四川省选 题目描述 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小于X ...
- BZOJ1067&P2471 [SCOI2007]降雨量[线段树裸题+细节注意]
dlntqlwsl 很裸的一道线段树题,被硬生生刷成了紫题..可能因为细节问题吧,我也栽了一次WA50分.不过这个隐藏条件真的对本菜鸡来说不易发现啊. 未知的年份连续的就看成一个就好了,把年份都离散化 ...
- 洛谷P2471——[SCOI2007]降雨量
本机AC提交RE…… 传送门:QAQQAQ 题意:自己看 思路:据说这道题用RMQ做很快,但这道题线段树是可以的 线段树维护一段区间最左年,最右年,是否有间隙和区间最大值 这道题分类讨论是一大难点,主 ...
- 【线段树 细节题】bzoj1067: [SCOI2007]降雨量
主要还是细节分析:线段树作为工具 Description 我们常常会说这样的话:“X年是自Y年以来降雨量最多的”.它的含义是X年的降雨量不超过Y年,且对于任意Y<Z<X,Z年的降雨量严格小 ...
- [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 ...
随机推荐
- docker虚拟机动态扩展内存
需求:将一台docker虚拟机的内存从6G扩展到8G. 关于资源限制,docker使用的是cgroup,这里就不细说原理了,只记录一下操作方法. 1.先找到容器ID # docker ps 2.进入对 ...
- 控制对象的创建方式(禁止创建栈对象or堆对象)和创建的数量
我们知道,C++将内存划分为三个逻辑区域:堆.栈和静态存储区.既然如此,我称位于它们之中的对象分别为堆对象,栈对象以及静态对象.通常情况下,对象创建在堆上还是在栈上,创建多少个,这都是没有限制的.但是 ...
- 解题:HDU 4609 Three Idiots
题面 要求组合的方法显然我们需要对桶卷积,即设$F(x)=\sum\limits_{i=1}^{maxx}x^{cnt[i]}$,然后我们初步的先把$F^2(x)$卷出来,表示选两条边.然后我们发现如 ...
- 图像处理之CSC性能优化(源码)
1 CSC基本实现 根据前一篇CSC转换的文档了解到,RGB与YUV的变换公式如下: YCbCr(256 级别) 可以从8位 RGB 直接计算,计算公式如下: Y = 0.299 R + 0.587 ...
- UESTC--1548
题目:Easy math 原题链接:http://acm.uestc.edu.cn/problem.php?pid=1548 分析:费马小定理的应用. #include<cstdio> # ...
- P1564 膜拜
P1564 膜拜 题目描述 神牛有很多-当然-每个同学都有自己衷心膜拜的神牛. 某学校有两位神牛,神牛甲和神牛乙.新入学的N 位同学们早已耳闻他们的神话. 所以,已经衷心地膜拜其中一位了.现在,老师要 ...
- 博世传感器调试笔记(三)加速度及地磁传感器BMC156
一. 器件简介:1. BMC 156是一款整合三轴地磁传感器与三轴(12bit)加速度传感器于一体的传感器,以BMC 150 电子罗盘模块为基础, 并与Bosch Sensortec 2x ...
- svn 节点处冲突 解决
问题描述: [root@localhost ] $ svn up 正在升级 ‘.’: 已跳过 ‘bg0605’ – 节点处于冲突状态 版本 175. 冲突概要: 跳过的路径:1 解决方法: 当前目录下 ...
- hihoCoder #1143 : 骨牌覆盖问题·一
#1143 : 骨牌覆盖问题·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 骨牌,一种古老的玩具.今天我们要研究的是骨牌的覆盖问题:我们有一个2xN的长条形棋盘,然 ...
- codevs 1540 1540 银河英雄传说
1540 银河英雄传说 题目描述 Description 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银 ...