[IOI2014]Wall

题目大意:

给你一个长度为\(n(n\le2\times10^6)\)的数列,初始全为\(0\)。\(m(m\le5\times10^5)\)次操作,每次让区间\([l_i,r_i]\)对\(h_i\)取\(\max/\min\),求最后每一个数的值。

思路:

线段树维护区间内数的上界和下界。

源代码:

#include<climits>
#include<algorithm>
#include"lib1895.h"
const int N=2e6+1;
class SegmentTree {
#define _left <<1
#define _right <<1|1
#define mid ((b+e)>>1)
private:
int u[N<<2],d[N<<2];
void upd1(const int &p,const int &x) {
if(u[p]!=INT_MAX&&d[p]>=x) return;
d[p]=std::max(d[p],x);
u[p]=std::max(u[p],x);
}
void upd2(const int &p,const int &x) {
if(d[p]!=INT_MIN&&u[p]<=x) return;
u[p]=std::min(u[p],x);
d[p]=std::min(d[p],x);
}
void push_down(const int &p) {
if(d[p]!=INT_MIN) {
upd1(p _left,d[p]);
upd1(p _right,d[p]);
d[p]=INT_MIN;
}
if(u[p]!=INT_MAX) {
upd2(p _left,u[p]);
upd2(p _right,u[p]);
u[p]=INT_MAX;
}
}
public:
void build(const int &p,const int &b,const int &e) {
u[p]=INT_MAX;
d[p]=INT_MIN;
if(b==e) return;
build(p _left,b,mid);
build(p _right,mid+1,e);
}
void modify1(const int &p,const int &b,const int &e,const int &l,const int &r,const int &x) {
if(b==l&&e==r) {
upd1(p,x);
return;
}
push_down(p);
if(l<=mid) modify1(p _left,b,mid,l,std::min(mid,r),x);
if(r>mid) modify1(p _right,mid+1,e,std::max(mid+1,l),r,x);
}
void modify2(const int &p,const int &b,const int &e,const int &l,const int &r,const int &x) {
if(b==l&&e==r) {
upd2(p,x);
return;
}
push_down(p);
if(l<=mid) modify2(p _left,b,mid,l,std::min(mid,r),x);
if(r>mid) modify2(p _right,mid+1,e,std::max(mid+1,l),r,x);
}
int query(const int &p,const int &b,const int &e,const int &x) {
if(b==e) {
int ret=0;
ret=std::max(ret,d[p]);
ret=std::min(ret,u[p]);
return ret;
}
int ret=0;
push_down(p);
if(x<=mid) ret=query(p _left,b,mid,x);
if(x>mid) ret=query(p _right,mid+1,e,x);
return ret;
}
#undef _left
#undef _right
#undef mid
};
SegmentTree sgt;
void buildWall(int n,int m,int opt[],int l[],int r[],int h[],int ans[]) {
sgt.build(1,1,n);
for(register int i=0;i<m;i++) l[i]++;
for(register int i=0;i<m;i++) r[i]++;
for(register int i=0;i<m;i++) {
if(opt[i]==1) sgt.modify1(1,1,n,l[i],r[i],h[i]);
if(opt[i]==2) sgt.modify2(1,1,n,l[i],r[i],h[i]);
}
for(register int i=0;i<n;i++) {
ans[i]=sgt.query(1,1,n,i+1);
}
}

[IOI2014]Wall的更多相关文章

  1. 4364: [IOI2014]wall砖墙

    4364: [IOI2014]wall砖墙 链接 分析: 线段树,维护一个最大值,一个最小值. 代码: #include<bits/stdc++.h> ],*p1 = buf,*p2 = ...

  2. bzoj4364: [IOI2014]wall砖墙

    线段树打标记的好(luo)题 打打标记,记得下移 = =听说2000000是用来卡线段树的 = =怎么办呢,,, = =打个读入优化看看能不能卡过去吧 #include<cstdio> # ...

  3. BZOJ4364: [IOI2014]wall砖墙(线段树)

    题意 题目链接 Sol 一个显然的思路是维护最大最小值以及最大最小值的覆盖标记. https://paste.ubuntu.com/p/WXpBvzF6Y2/ 但实际上因为这题只需要输出最后的操作序列 ...

  4. 【[IOI2014]Wall 砖墙】

    好像随便一卡就最优解了 malao告诉我这道题挺不错的,于是就去写了写 这两个操作很有灵性啊,感觉这么有特点的数大概是需要分块维护的吧 但是并没有什么区间查询,只是在最后输出整个序列 于是我们就直接用 ...

  5. BZOJ4364:[IOI2014]Wall

    浅谈区间最值操作与历史最值问题:https://www.cnblogs.com/AKMer/p/10225100.html 题目传送门:https://lydsy.com/JudgeOnline/pr ...

  6. P4560 [IOI2014]Wall 砖墙

    题目描述 给定一个长度为 nn且初始值全为 00的序列.你需要支持以下两种操作: Add L, R, hL,R,h:将序列 [L, R][L,R]内所有值小于 hh的元素都赋为 hh,此时不改变高度大 ...

  7. LUOGU P4560 [IOI2014]Wall 砖墙 (线段树)

    传送门 解题思路 线段树打标记,刚开始想复杂了,维护了四个标记.后来才知道只需要维护一个最大值最小值即可,然后更新的时候分类讨论一下. 代码 #include<iostream> #inc ...

  8. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  9. 「IOI2014」Wall 砖墙

    题目描述 给定一个初始元素为 \(0\) 的数列,以及 \(K\) 次操作: 将区间 \([L, R]\) 中的元素对 \(h\) 取 \(max\) 将区间 \([L, R]\) 中的元素对 \(h ...

随机推荐

  1. Duplicate 复制数据库 搭建Dataguard

    1 操作系统环境 此处隐藏具体信息 System IP-address db_name db_version Comment         Target DB         Auxiliary D ...

  2. Nlog日志之File

    一:简介 NLog是一个简单灵活的.NET日志记录类库.通过使用NLog,我们可以在任何一种.NET语言中输出带有上下文的(contextual information)调试诊断信息,根据喜好配置其表 ...

  3. Centos+Redis 集群

    Redis 3.2.6集群搭建 Redis3.0版本之后支持Cluster. 1.1.redis cluster的现状 目前redis支持的cluster特性: 1):节点自动发现 2):slave- ...

  4. FATAL Fatal error during KafkaServerStable startup. Prepare to shutdown (kafka.server.KafkaServerStartable) java.io.FileNotFoundException: /tmp/kafka-logs/.lock (Permission denied)

    1.启动kafka的时候,报错如下所示: [-- ::,] INFO zookeeper state changed (SyncConnected) (org.I0Itec.zkclient.ZkCl ...

  5. EF批量插入数据(Z.EntityFramework.Extensions)

    EF用原生的插入数据方法DbSet.ADD()和 DbSet.AddRange()都很慢.所以要做大型的批量插入只能另选它法. 1.Nugget 2.代码 using EF6._0Test.EF; u ...

  6. [转] mongoose学习笔记(超详细)

    名词解释 Schema: 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力 Model: 由Schema编译而成的假想(fancy)构造器,具有抽象属性和行为.Model的每一个实例(ins ...

  7. ionic 3 build后图片无法显示

    运行命令 ionic cordova build android 生成了android-debug.apk. /home/han/project/zero_app/platforms/android/ ...

  8. 【AtCoder】ARC072

    ARC072 C - Sequence 直接认为一个数是正的,或者第一个数是负的,每次将不合法的负数前缀和改成+1正数前缀和改成-1 #include <bits/stdc++.h> #d ...

  9. day43 mysql 基本管理,[破解密码以及用户权限设置]以及慢日志查询配置

    配置文件:详细步骤, 1,找到mysql的安装包,然后打开后会看到一个my.ini命名的程序,把它拖拽到notepad++里面来打开,(应该是其他文本形式也可以打开,可以试一下),直接拖拽即可打开该文 ...

  10. day19 正则,re模块

    http://www.cnblogs.com/Eva-J/articles/7228075.html  所有常用模块的用法 正则的规则: 在一个字符组里面枚举合法的所有字符,字符组里面的任意一个字符和 ...