[BZOJ 2957]楼房重建(THU2013集训)(线段树维护单调栈)
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2957
分析:
根据题意,就是比较斜率大小
只看一段区间的话,那么这段区间能看见的楼房数量就是这段区间的单调栈的大小
那么这题就是用线段树来维护这个单调栈
len[k]表示对于区间k来说单调栈的大小是多少
那么自底向上maintain(k)的时候,len[k]=len[lson]+find(rson,max[lson])
find(k,x)就是表示以数字x进去k区间,那么能走的步数是多少
那么find(k,x)怎么求呢?
①如果x>max[lson],就说明左区间贡献是0,那么该答案就是find(rson,x)
②如果x<=max[lson],那就说明左区间是有贡献的,那么该答案就是find(lson,x)+find(rson,max[lson])
等等,对于情况②,我们两边都要递归下去,那岂不是复杂度退化到O(n)了?
其实我们发现这个find(rson,max[lson])是没必要递归下去的,可以提前预处理(实际上,该值等于len[k]-len[lson],因为是自底向上合并信息,所以len[k]与len[lson]已经求出来了)
时间复杂度是O(nlog^2n)的
[BZOJ 2957]楼房重建(THU2013集训)(线段树维护单调栈)的更多相关文章
- [CSP-S模拟测试]:陶陶摘苹果(线段树维护单调栈)
		题目传送门(内部题116) 输入格式 第一行两个整数$n,m$,如题 第二行有$n$个整数表示$h_1-h_n(1\leqslant h_i\leqslant 10^9)$ 接下来有$m$行,每行两个 ... 
- 洛谷 P4198 楼房重建 线段树维护单调栈
		P4198 楼房重建 题目链接 https://www.luogu.org/problemnew/show/P4198 题目描述 小A的楼房外有一大片施工工地,工地上有N栋待建的楼房.每天,这片工地上 ... 
- [CSP-S模拟测试]:God Knows(线段树维护单调栈)
		题目描述 小$w$来到天堂的门口,对着天堂的大门发呆.大门上有一个二分图,左边第$i$个点连到右边第$p_i$个点.(保证$p_i$是一个排列).小$w$每次可以找左边某个对应连线尚未被移除的点$i$ ... 
- BZOJ 2957楼房重建
		传送门 线段树 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> #include< ... 
- 【洛谷5294】[HNOI2019] 序列(主席树维护单调栈+二分)
		点此看题面 大致题意: 给你一个长度为\(n\)的序列\(A\),每次询问修改一个元素(只对当前询问有效),然后让你找到一个不下降序列\(B\),使得这两个序列相应位置之差的平方和最小,并输出这个最小 ... 
- bzoj 2957: 楼房重建 线段树
		2957: 楼房重建 Time Limit: 10 Sec Memory Limit: 256 MB[Submit][Status][Discuss] Description 小A的楼房外有一大片施 ... 
- BZOJ 2957 楼房重建 (线段树)
		题目链接 楼房重建 解题思路:我们可以把楼房的最高点的斜率计算出来.那么问题就转化成了实时查询x的个数,满足数列x的左边没有大于等于x的数. 我们可以用线段树维护 设t[i]为如果只看这个区间,可以 ... 
- bzoj 2957: 楼房重建 ——线段树
		Description 小A的楼房外有一大片施工工地,工地上有N栋待建的楼房.每天,这片工地上的房子拆了又建.建了又拆.他经常无聊地看着窗外发呆,数自己能够看到多少栋房子. 为了简化问题,我们考虑这些 ... 
- [BZOJ 3995] [SDOI2015] 道路修建 【线段树维护连通性】
		题目链接:BZOJ - 3995 题目分析 这道题..是我悲伤的回忆.. 线段树维护连通性,与 BZOJ-1018 类似,然而我省选之前并没有做过 1018,即使它在 ProblemSet 的第一页 ... 
随机推荐
- uiautomator+cucumber实现移动app自动化测试
			前提 由于公司业务要求,所以自动化测试要达到以下几点: 跨应用的测试 测试用例可读性强 测试报告可读性强 对失败的用例有截图保存并在报告中体现 基于以上几点,在对自动化测试框架选型的时候就选择了uia ... 
- excel批量导入
			https://www.cnblogs.com/mingyue1818/p/4828865.html 
- ansible自动部署Keepalived实现Nginx服务双机热备
			脚本实现通过ansible-playbook自动化安装Keepalived和配置,主要解决问题如下: Keepalived自动化安装: keepalived_vrid配置,自动根据vip获取最后一段作 ... 
- Leetcode 668.乘法表中第k小的数
			乘法表中第k小的数 几乎每一个人都用 乘法表.但是你能在乘法表中快速找到第k小的数字吗? 给定高度m .宽度n 的一张 m * n的乘法表,以及正整数k,你需要返回表中第k 小的数字. 例 1: 输入 ... 
- 架构师入门ing
			算法竞赛水平一般,算法工程师估计遥遥无期,准备开始架构方面的学习. 单纯依靠垂直提升硬件性能来提高系统性能的时代已结束,分布式开发的时代实际上早已悄悄地成为了时代的主流. 在一个团队里,架构师充当了技 ... 
- 团队冲刺Alpha(七)
			目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:凯琳 组员6:翟丹丹 组员7:何家伟 组员8:政演 组员9:黄鸿杰 组员10:刘一好 组员11:何宇恒 展示 ... 
- [codeforces934E]A Colourful Prospect
			[codeforces934E]A Colourful Prospect 试题描述 Firecrackers scare Nian the monster, but they're wayyyyy t ... 
- JAVA输出最大值和最小值
			public class MaxMin{ public static void main(String[] args) { int[] arr = new int[6]; Scanner input ... 
- classpath: spring 中的查找方式
			Spring可以通过指定classpath*:与classpath:前缀加路径的方式从classpath加载文件,如bean的定义文件.classpath*:的出现是为了从多个jar文件中加载相同的文 ... 
- 转:mysql group by
			group by 用法解析 group by语法可以根据给定数据列的每个成员对查询结果进行分组统计,最终得到一个分组汇总表. SELECT子句中的列名必须为分组列或列函数.列函数对于GROUP BY子 ... 
