Codeforces 484E Sign on Fence(是持久的段树+二分法)
题目链接:Codeforces 484E Sign on Fence
题目大意:给定给一个序列,每一个位置有一个值,表示高度,如今有若干查询,每次查询l,r,w,表示在区间l,r中,
连续最长长度大于w的最大高度为多少。
解题思路:可持久化线段树维护区间合并,前端时间碰到一题可持久化字典树,就去查了一下相关论文,大概知道了是
什么东西。
将高度依照从大到小的顺序排序,然后每次插入一个位置,线段树维护最长连续区间,由于插入是依照从大到小的顺
序,所以每次的线段树中的连续最大长度都是满足高度大于等于当前新插入的height值。对于每次查询,二分高度,因
为高度肯定是在已有的高度中,所以仅仅接二分下表就可以。
#include <cstdio>
#include <cstring>
#include <vector>
#include <algorithm>
using namespace std;
const int maxn = 1e6 + 5;
typedef pair<int,int> pii;
struct Node {
int lc, rc, lp, rp, L, R, S;
int length() {
return rp - lp + 1;
}
}nd[maxn << 2];
int N, sz, root[maxn];
pii blo[maxn];
inline int newNode() {
return sz++;
}
inline void pushup(int u) {
int lcid = nd[u].lc, rcid = nd[u].rc;
nd[u].L = nd[lcid].L + (nd[lcid].L == nd[lcid].length() ? nd[rcid].L : 0);
nd[u].R = nd[rcid].R + (nd[rcid].R == nd[rcid].length() ? nd[lcid].R : 0);
nd[u].S = max(nd[lcid].R + nd[rcid].L, max(nd[lcid].S, nd[rcid].S));
}
inline Node merge(Node a, Node b) {
Node u;
u.lp = a.lp; u.rp = b.rp;
u.L = a.L + (a.L == a.length() ? b.L : 0);
u.R = b.R + (b.R == b.length() ? a.R : 0);
u.S = max(a.R + b.L, max(a.S, b.S));
return u;
}
void build(int& u, int l, int r) {
if (u == 0) u = newNode();
nd[u] = (Node){0, 0, l, r, 0, 0, 0};
if (l == r)
return;
int mid = (l + r) >> 1;
build(nd[u].lc, l, mid);
build(nd[u].rc, mid +1, r);
pushup(u);
}
int insert(int u, int x) {
int k = newNode();
nd[k] = nd[u];
if (nd[k].lp == x && x == nd[k].rp) {
nd[k].S = nd[k].L = nd[k].R = 1;
return k;
}
int mid = (nd[k].lp + nd[k].rp) >> 1;
if (x <= mid)
nd[k].lc = insert(nd[k].lc, x);
else
nd[k].rc = insert(nd[k].rc, x);
pushup(k);
return k;
}
Node query(int u, int l, int r) {
if (l <= nd[u].lp && nd[u].rp <= r)
return nd[u];
int mid = (nd[u].lp + nd[u].rp) >> 1;
if (r <= mid)
return query(nd[u].lc, l, r);
else if (l > mid)
return query(nd[u].rc, l, r);
else {
Node ll = query(nd[u].lc, l, r);
Node rr = query(nd[u].rc, l, r);
return merge(ll, rr);
}
}
inline bool cmp (const pii& a, const pii& b) {
return a.first > b.first;
}
void init () {
sz = 1;
scanf("%d", &N);
for (int i = 1; i <= N; i++) {
scanf("%d", &blo[i].first);
blo[i].second = i;
}
sort(blo + 1, blo + 1 + N, cmp);
build(root[0], 1, N);
for (int i = 1; i <= N; i++)
root[i] = insert(root[i-1], blo[i].second);
}
int main () {
init();
int q, l, r, w;
scanf("%d", &q);
while (q--) {
scanf("%d%d%d", &l, &r, &w);
int L = 1, R = N;
while (L < R) {
int mid = (L + R) >> 1;
if (query(root[mid], l, r).S >= w)
R = mid;
else
L = mid + 1;
}
printf("%d\n", blo[L].first);
}
return 0;
}
Codeforces 484E Sign on Fence(是持久的段树+二分法)的更多相关文章
- (困难) CF 484E Sign on Fence,整体二分+线段树
Bizon the Champion has recently finished painting his wood fence. The fence consists of a sequence o ...
- CF 484E - Sign on Fence
E. Sign on Fence time limit per test 4 seconds memory limit per test 256 megabytes input standard in ...
- BZOJ 2588 Count on a tree (COT) 是持久的段树
标题效果:两棵树之间的首次查询k大点的权利. 思维:树木覆盖树,事实上,它是正常的树木覆盖了持久段树. 由于使用权值段树可以寻求区间k大,然后应用到持久段树思想,间隔可以做减法.详见代码. CODE: ...
- Codeforces Round #276 (Div. 1) E. Sign on Fence (二分答案 主席树 区间合并)
链接:http://codeforces.com/contest/484/problem/E 题意: 给你n个数的,每个数代表高度: 再给出m个询问,每次询问[l,r]区间内连续w个数的最大的最小值: ...
- AC日记——Sign on Fence Codeforces 484e
E. Sign on Fence time limit per test 4 seconds memory limit per test 256 megabytes input standard in ...
- CF&&CC百套计划4 Codeforces Round #276 (Div. 1) E. Sign on Fence
http://codeforces.com/contest/484/problem/E 题意: 给出n个数,查询最大的在区间[l,r]内,长为w的子区间的最小值 第i棵线段树表示>=i的数 维护 ...
- Codeforces Round #276 (Div. 1) E. Sign on Fence 二分+主席树
E. Sign on Fence Bizon the Champion has recently finished painting his wood fence. The fence consi ...
- codeforces 349B Color the Fence 贪心,思维
1.codeforces 349B Color the Fence 2.链接:http://codeforces.com/problemset/problem/349/B 3.总结: 刷栅栏.1 ...
- 【CF484E】Sign on Fence(主席树)
[CF484E]Sign on Fence(主席树) 题面 懒得贴CF了,你们自己都找得到 洛谷 题解 这不就是[TJOI&HEOI 排序]那题的套路吗... 二分一个答案,把大于答案的都变成 ...
随机推荐
- 基于模糊Choquet积分的目标检测算法
本文根据论文:Fuzzy Integral for Moving Object Detection-FUZZ-IEEE_2008的内容及自己的理解而成,如果想了解更多细节,请参考原文.在背景建模中,我 ...
- 【剑指offer】约瑟夫环问题
转载请注明出处:http://blog.csdn.net/ns_code/article/details/27957407 题目描写叙述: 每年六一儿童节,JOBDU都会准备一些小礼物去看望孤儿院的小 ...
- Nginx 进程间通信
Linux下的IPC非常多,nginx的进程都是有亲缘关系的进程,对于他们的通信我们选择TCP socket进行通信. TCP socket 用来做进程通信的优点有, 1.socket是文件描 ...
- 断言Assert的使用
转载地址:http://www.cnblogs.com/moondark/archive/2012/03/12/2392315.html 我一直以为assert仅仅是个报错函数,事实上,它居然是个宏 ...
- firebug登陆之数据包分析
登陆之数据包分析 工具: python-urllib2 | firefox+firebug或者chrome,用浏览器打开登陆页面之后,按F12键会默认打开开发者工具或者启动firebug,点击n ...
- Drools学习笔记-01-在eclipse indgo集成Drools5.5
1.1.条件 Drools它是一个基于Java开源规则引擎.因此,使用Drools以及前需要安装在开发机器JDK周边环境,Drools5.5需要JDK版本号的1.5或者更多. 1.2.开发环境搭建 大 ...
- python基础课程_2学习笔记3:图形用户界面
图形用户界面 丰富的平台 写作Python GUI程序前,须要决定使用哪个GUI平台. 简单来说,平台是图形组件的一个特定集合.能够通过叫做GUI工具包的给定Python模块进行訪问. 工具包 描写叙 ...
- bestcoder Round#52 1001(最短路+状压dp)
求从1点出发,走遍所有的点,然后回到1点的最小代价. 每个点可以走若干遍. 如果每个点只能走一遍,那么设dp[i][s]为走完s状态个点(s是状态压缩),现在位于i的最小花费. 然后枚举从哪个点回到原 ...
- leetcode先刷_Binary Tree Level Order Traversal II
非常easy标题,在后面,我不认为它不是那么简单的回答更多的.我们将编写,没有人啊. 预购在基层上,加上节省每一层,加上从下往上的输出,是一家vector而一个stack那么问题,没有他,但另一方面- ...
- Visibility属性实现自动隐藏功能
//使用一个Button,鼠标移入listView显示,移出隐藏 private void button2_MouseEnter(object sender, System.Windows.Input ...