计蒜客16492 building(二分线段树/分块)
题解:
考虑用线段树维护楼的最大值,然后这个问题就很简单了。
每次可以向左二分出比x高的第一个楼a,同理也可以向右二分出另一个楼b,如果a,b都存在,答案就是b-a-1。
注意到二分是可以直接在线段树上进行的,所以复杂度是O(nlogn)。
当然这里是用分块做的,更暴力一些。
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
using namespace std;
const int maxn = 1e5 + , maxN = ;
int B[maxN], Tag[maxN];
int a[maxn];
int n, m, N, L;
void Update(int i){
if(Tag[i] == -) return;
int bl = i*L, br = min(n, (i+)*L-);
for(int j = bl; j <= br; j++) a[j] = Tag[i];
Tag[i] = -;
}
void Change(int l, int r, int v){
for(int i = ; i < N; i++){
int bl = i*L, br = min(n, (i+)*L-);
if(l <= bl && br <= r){
Tag[i] = v;
B[i] = v;
} else if(bl <= l && l <= br && bl <= r && r <= br){
Update(i);
B[i] = max(B[i], v);
for(int j = l; j <= r; j++) a[j] = v;
} else if(bl <= l && l <= br){
Update(i);
B[i] = max(B[i], v);
for(int j = l; j <= br; j++) a[j] = v;
} else if(bl <= r && r <= br){
Update(i);
B[i] = max(B[i], v);
for(int j = bl; j <= r; j++) a[j] = v;
}
}
} int Findl(int x){
int bi = x/L;
int bl = bi*L, br = min(n, (bi+)*L-);
Update(bi);
for(int i = x-; i >= bl; i--){
if(a[i] > a[x]) return i;
}
for(int i = bi-; i >= ; i--){
if(B[i] > a[x]){
bl = i*L, br = min(n, (i+)*L-);
Update(i);
for(int j = br; j >= bl; j--)
if(a[j] > a[x]) return j;
}
}
return -;
} int Findr(int x){
int bi = x/L;
int bl = bi*L, br = min(n, (bi+)*L-);
Update(bi);
for(int i = x+; i <= br; i++){
if(a[i] > a[x]) return i;
}
for(int i = bi+; i < N; i++){
if(B[i] > a[x]){
bl = i*L, br = min(n, (i+)*L-);
Update(i);
for(int j = bl; j <= br; j++)
if(a[j] > a[x]) return j;
}
}
return -;
} int main()
{
int x, y, z;
cin>>n;
for(int i = ; i <= n; i++){
scanf("%d", &a[i]);
}
L = sqrt(n+0.5);
N = n/L + ;
for(int i = ; i < N; i++) Tag[i] = -;
for(int i = ; i <= n; i++){
B[i/L] = max(B[i/L], a[i]);
}
cin>>m;
for(int i = ; i <= m; i++){
scanf("%d", &x);
if(x == ){
scanf("%d %d %d", &x, &y, &z);
Change(x, y, z);
} else {
scanf("%d", &x);
int l = Findl(x), r = Findr(x);
if(l == - || r == -) printf("-1\n");
else printf("%d\n", r-l-);
}
}
}
计蒜客16492 building(二分线段树/分块)的更多相关文章
- 【原创】tyvj1038 忠诚 & 计蒜客 管家的忠诚 & 线段树(单点更新,区间查询)
最简单的线段树之一,中文题目,不翻译.... 注释讲的比较少,这已经是最简单的线段树,如果看不懂真的说明最基础的理论没明白 推荐一篇文章http://www.cnblogs.com/liwenchi/ ...
- [计蒜客T2238]礼物_线段树_归并排序_概率期望
礼物 题目大意: 数据范围: 题解: 这题有意思啊($md$卡常 直接做怎么做? 随便上个什么东西,维护一下矩阵乘和插入,比如说常数还算小的$KD-Tree$(反正我是没见人过过 我们漏掉了一个条件, ...
- 计蒜客 28315.Excellent Engineers-线段树(单点更新、区间最值) (Benelux Algorithm Programming Contest 2014 Final ACM-ICPC Asia Training League 暑假第一阶段第二场 E)
先写这几道题,比赛的时候有事就只签了个到. 题目传送门 E. Excellent Engineers 传送门 这个题的意思就是如果一个人的r1,r2,r3中的某一个比已存在的人中的小,就把这个人添加到 ...
- 计蒜客 38228. Max answer-线段树维护单调栈(The Preliminary Contest for ICPC China Nanchang National Invitational I. Max answer 南昌邀请赛网络赛) 2019ICPC南昌邀请赛网络赛
Max answer Alice has a magic array. She suggests that the value of a interval is equal to the sum of ...
- 计蒜客 41391.query-二维偏序+树状数组(预处理出来满足情况的gcd) (The Preliminary Contest for ICPC Asia Xuzhou 2019 I.) 2019年徐州网络赛)
query Given a permutation pp of length nn, you are asked to answer mm queries, each query can be rep ...
- 计蒜客 Prefix Free Code(字典树+树状数组)
Consider n initial strings of lower case letters, where no initial string is a prefix of any other i ...
- [计蒜客] 矿石采集【记搜、Tarjan缩点+期望Dp】
Online Judge:计蒜客信息学3月提高组模拟赛 Label:记搜,TarJan缩点,树状数组,期望Dp 题解 整个题目由毫无关联的两个问题组合成: part1 问题:对于每个询问的起点终点,求 ...
- 计蒜客 NOIP 提高组模拟竞赛第一试 补记
计蒜客 NOIP 提高组模拟竞赛第一试 补记 A. 广场车神 题目大意: 一个\(n\times m(n,m\le2000)\)的网格,初始时位于左下角的\((1,1)\)处,终点在右上角的\((n, ...
- 计蒜客 28449.算个欧拉函数给大家助助兴-大数的因子个数 (HDU5649.DZY Loves Sorting) ( ACM训练联盟周赛 G)
ACM训练联盟周赛 这一场有几个数据结构的题,但是自己太菜,不会树套树,带插入的区间第K小-替罪羊套函数式线段树, 先立个flag,BZOJ3065: 带插入区间K小值 计蒜客 Zeratul与Xor ...
随机推荐
- Spring Boot2.0拦截器简单实现判断是否登录
在进行项目开发的时候使用springboot框架用到拦截器时发现2.0以后原来的抽象类WebMvcConfigurerAdapter已经过时了,去官网查文档2.x版本要实现拦截器功能改为需要继承Web ...
- git中如何忽略文件上传?
使用原因:至于我们为什么要使用git忽略文件,原因很多.就比如我自己的情况吧!自己一个人多地方开发,为了代码同步,这样很方便.但是有个问题就是,我创建 的是开源项目,上面有一些服务器上面的配置信息,这 ...
- Yii 2.0.6 - 从入口到Action执行
defined('YII_DEBUG') or define('YII_DEBUG', true); defined('YII_ENV') or define('YII_ENV', 'dev'); r ...
- react native 踩坑之 SectionList state更新 不执行render重新渲染页面
官方文档中指出 SectionList 本组件继承自PureComponent而非通常的Component,这意味着如果其props在浅比较中是相等的,则不会重新渲染.所以请先检查你的renderIt ...
- ruby 第三方模块unirest使用
Creating Requests require 'unirest' response = Unirest.post 'http://httpbin.org/post', headers:{ Acc ...
- mysql5.6主主复制及keepalived 高可用
1.实验目的 mysql服务器作为生产环境中使用最广泛的数据库软件,以其开源性,稳定性而广泛使用,但同时由于数据存储,读写频率高,极易造成数据库出错,从而给企业造成不可挽回的损失,我们除了做好数据库的 ...
- 剑指offer题目系列二
本篇延续上一篇,介绍<剑指offer>第二版中的四个题目:从尾到头打印链表.用两个栈实现队列.旋转数组的最小数字.二进制中1的个数. 5.从尾到头打印链表 题目:输入一个链表的头结点,从尾 ...
- java 第三章 流程控制语句
1.条件语句 (1)if 语句 ( 单一条件) if (表达式){ 执行语句块 } (2)执行流程 · if 语句 条件表达式可以是任何一种逻辑表达式 如果表达式值为true,则执行花括号的内容后 ...
- 1139: [POI2009]Wie
1139: [POI2009]Wie https://www.lydsy.com/JudgeOnline/problem.php?id=1139 分析: Dijkstra.状压最短路,dis[i][j ...
- Windows自带的磁盘填充命令
一张不用了的SD卡要给别人,之前一直是手机使用的,担心有一些资料被恢复,想要将它内容清空.以前就知道数字公司有一个磁盘填充的工具,后来网上搜一搜发现Windows有一个自带的命令用于磁盘填充. 首先进 ...