题目大意

传送门

题解

我国古代有一句俗话。

骗分出奇迹,乱搞最神奇!

这句话在这道题上得到了鲜明的体现。

我的方法就是魔改版线段树,乱搞搞一下,首先借鉴了黄学长的建树方法,直接用一个节点维护年份的区间,但是这样就带来了问题,就是在查询的时候非常难以操作。经过不断的乱搞,我终于把正确的操作方式搞了出来。。。

另外这个题细节还是很多。详见胡泽聪dalao的分析

代码

#include <bits/stdc++.h>
using namespace std;
const int maxn = 50005;
struct seg {
int l, r, mx, know;
} t[maxn * 4];
int s[maxn], n, m;
void build(int k, int l, int r) {
if (l == r) {
scanf("%d %d", &t[k].l, &t[k].mx);
t[k].r = t[k].l;
t[k].know = 1;
return;
}
int mid = (l + r) >> 1;
build(k << 1, l, mid);
build(k << 1 | 1, mid + 1, r);
t[k].know = (t[k << 1].know && t[k << 1 | 1].know);
if (t[k << 1].r + 1 != t[k << 1 | 1].l)
t[k].know = 0;
t[k].l = t[k << 1].l;
t[k].r = t[k << 1 | 1].r;
t[k].mx = max(t[k << 1].mx, t[k << 1 | 1].mx);
}
int query_mx(int k, int x, int y) {
int l = t[k].l, r = t[k].r;
if (y < x)
return 0;
if (x < l)
x = l;
if (y > r)
y = r;
if (x == l && r == y)
return t[k].mx;
int mid = t[k << 1].r;
int nxmid = t[k << 1 | 1].l;
if (y < l || x > r)
return 0;
int ans = -0x3f3f3f;
if (x >= l && y < nxmid && x <= mid) {
ans = max(ans, query_mx(k << 1, x, y));
} else if (y <= r && x > mid && y >= nxmid) {
ans = max(ans, query_mx(k << 1 | 1, x, y));
} else if (x >= l && x <= mid && y >= nxmid && y <= r) {
ans = max(ans, query_mx(k << 1, x, mid));
ans = max(ans, query_mx(k << 1 | 1, nxmid, y));
} else
return 0;
return ans;
}
int query_know(int k, int x, int y) {
int l = t[k].l, r = t[k].r;
if (y < x)
return 0;
if (x < l || y > r)
return 0;
if (x == l && y == r)
return t[k].know;
else if (r - l == 0)
return 0;
bool ans = true;
int mid = t[k << 1].r;
int nxmid = t[k << 1 | 1].l;
if (x >= l && y < nxmid && x <= mid) {
ans = ans && query_know(k << 1, x, y);
} else if (y <= r && x > mid && y >= nxmid) {
ans = ans && query_know(k << 1 | 1, x, y);
} else if (x >= l && x <= mid && y >= nxmid && y <= r) {
ans = ans && query_know(k << 1, x, mid);
ans = ans && query_know(k << 1 | 1, nxmid, y);
ans = ans && (nxmid-mid <= 1) ? 1 : 0;
} else
return 0;
return ans;
}
int query(int k, int x) {
if (t[k].l == t[k].r)
return t[k].mx;
if (x <= t[k << 1].r)
return query(k << 1, x);
else if (x >= t[k << 1 | 1].l)
return query(k << 1 | 1, x);
else
return -1;
}
int main() {
//freopen("rain.in", "r", stdin);
//freopen("rain.ans", "w", stdout);
scanf("%d", &n);
build(1, 1, n);
scanf("%d", &m);
// cout << query_mx(1, 2003, 2007);
//cout << query_know(1, -138, -129) << endl;
// cout << query_know(1, 2004, 2006) << endl;
for (int i = 1; i <= m; i++) {
int x, y;
scanf("%d %d", &x, &y);
if (query_know(1, x, y) && (query(1, x) >= query(1, y)) &&
(query_mx(1, x + 1, y - 1) < query(1, y)))
printf("true\n");
else if (query_know(1, x, x) && query_know(1, y, y) &&
!(query_know(1, x + 1, y - 1)) &&
(query_mx(1, x + 1, y - 1) < query(1, y)) &&
(query(1, x) >= query(1, y)))
printf("maybe\n");
else if (query_know(1, x, x) && !(query_know(1, y, y)) && (query_mx(1,x+1,y-1) < query(1,x)))
printf("maybe\n");
else if (query_know(1, y, y) && !(query_know(1, x, x)) &&
(query_mx(1, x + 1, y - 1) < query(1, y)))
printf("maybe\n");
else if ((!(query_know(1, x, x)) && (!(query_know(1, y, y)))))
printf("maybe\n");
else
printf("false\n");
}
return 0;
}

Ps.开始对着样例乱搞出的代码居然得了50分

[bzoj1067][SCOI2007]降雨量——线段树+乱搞的更多相关文章

  1. BZOJ1067 [SCOI2007]降雨量 线段树

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1067 题意概括 给定n组整数对(Xi,Yi),当Xi<Xj且Yi>=Yj时,如果对于任 ...

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

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

  3. 洛谷P5211 [ZJOI2017]字符串(线段树+乱搞)

    题面 传送门 题解 为什么大佬们全都是乱搞的--莫非这就是传说中的暴力能进队,乱搞能AC-- 似乎有位大佬能有纯暴力+玄学优化\(AC\)(不算上\(uoj\)的\(Hack\)数据的话--这要是放到 ...

  4. 【Luogu】P2221高速公路(线段树乱搞)

    题目链接 这题……我从一开始就想歪了qwq. 为了缅怀逝去的一小时我就把我的30分暴力思路放上来. 首先我们观察枚举的区间.假设我们要枚举的范围是1~5之间的四条路,为了方便我们把它们叫做abcd. ...

  5. [SCOI2007]降雨量 线段树和区间最值(RMQ)问题

      这道题是比较经典的 \(RMQ\) 问题,用线段树维护是比较简单好写的.比较难的部分是判断处理.如果没有想好直接打代码会调很久(没错就是我).怎么维护查询区间最大值我就不再这里赘述了,不懂线段树的 ...

  6. [BZOJ1067][SCOI2007]降雨量

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

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

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

  8. BZOJ-1067 降雨量 线段树+分类讨论

    这道B题,刚的不行,各种碎点及其容易忽略,受不鸟了直接 1067: [SCOI2007]降雨量 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 2859 ...

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

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

随机推荐

  1. IOS 实现TXT文本自动识别编码的方法

    from :http://kyoworkios.blog.51cto.com/878347/1344013 TXT识别编码是个复杂的问题.幸好有c/c++的一个库能识别. 库的叫uchardet,可以 ...

  2. cocoaPods的安装使用 以及 Carthage

    http://cnbin.github.io/blog/2015/05/25/cocoapods-an-zhuang-he-shi-yong/ 按照这个步骤就OK Note:当引入已有的project ...

  3. MVC+Repository+UOW+EntityFrmeWork的使用

    1.首先创建一个空的MVC3应用程序,命名为MyRepository.Web,解决方案命名为MyRepository. 2.添加一个类库项目,命名为MyRepository.DAL,添加一个文件夹命名 ...

  4. 安装pybloomfiltermmap 遇到bug

    pybloomfiltermmap pip 安装 : sudo pip install pybloomfiltermmap I want to try one program which have m ...

  5. CreateForm(

    /// <summary> /// 打开新的子窗体 /// </summary> /// <param name="strName">窗体的类名 ...

  6. iOS 之 手势

    手势操作,有一个总的抽象类UIGestureRecognizer,用于检测设备的所有手势.其下有多个子类: 拍击UITapGestureRecognizer (任意次数的拍击) 向里或向外捏UIPin ...

  7. UVa 10034 - Freckles

    题目大意:给出n个点的坐标(x,y),要求用线段将n个点连接起来,求最小的线段和. 最小生成树问题,用Kruskal算法进行求解,其中用到了并查集.将所有的点连接,构成一张图,对每一条边进行编号,两点 ...

  8. spark Intellij IDEA开发环境搭建

    (1)创建Scala项目 File->new->Project,如下图 选择Scala 然后next 其中Project SDK指定安装的JDK,Scala SDK指定安装的Scala(这 ...

  9. css3实战版的点击列表项产生水波纹动画——之jsoop面向对象封装版

    1.html: <!DOCTYPE html><html><head lang="en">    <meta charset=" ...

  10. iOS 之 工厂模式

    参考:http://www.jikexueyuan.com/course/2054_2.html?ss=2 1. 简单工厂 简单工厂类是一个实体类.用于几种相似类的统一创建,简化流程,隔离细节. 下面 ...