[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. IDEA窗口重置

  2. ubuntu下使用matplotlib绘图无法显示中文label

    原因是字体导致的.大家的做法基本都是搞一个windows上的字体文件(simhei.ttf, 点我fq下载)然后刷新一下缓存文件. 只不过百度搜到第一篇CSDN的博客,写的很不靠谱(不是所有的CSDN ...

  3. What's news in Visual Studio 2017

    文字总结: 1.高级智能提示  在属性列表中输入 M C即可查询属性中包含字母m\c的属性 2.更快的导航查询,在Go To All中输入任意查询的字符,可快速查到任何包含关键字的文件 3.代码智能分 ...

  4. TURN TAP: Temporal Unit Regression Network for Temporal Action Proposals(ICCV2017)

    Motivation 实现快速和准确地抽取出视频中的语义片段 Proposed Method -提出了TURN模型预测proposal并用temporal coordinate regression来 ...

  5. Windows无法自动将IP协议堆栈绑定到网络适配器 的解决办法

    实验室的台式机在升级驱动后上不了网了,有线网卡驱动卸载后重装了,还是不行,通过Windows诊断发现“Windows 无法自动将 IP 协议堆栈绑定到网络适配器的解决办法”. 解决办法: 打开“控制面 ...

  6. nodeJS有多快

    听说nodeJS适用于高并发的场景,一直想测试但是没找到机会 这几天新系统要上线了,老系统的数据需要割接到新的系统中 由于数据量很大,表的结构的发生了很大的改变,割接时间长达9个小时 其中一个模块有1 ...

  7. 解决 Ionic 浏览器跨域问题

    <system.webServer> <httpProtocol> <customHeaders> <add name="Access-Contro ...

  8. Codeforces 542A Place Your Ad Here

    Place Your Ad Here 把没用的第一类区间去掉之后, 排序, 然后枚举第二类区间, 在上面死命二分就好了. #include<bits/stdc++.h> #define L ...

  9. P1052 过河 线性dp 路径压缩

    题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可能到达的点看成数 ...

  10. spring的webutils包。适用于访问httpservletrequest和httpservletresponse

    WebUtils位 于 org.springframework.web.util 包中的 WebUtils 是一个非常好用的工具类,它对很多 Servlet API 提供了易用的代理方法,降低了访问 ...