好像随便一卡就最优解了

malao告诉我这道题挺不错的,于是就去写了写

这两个操作很有灵性啊,感觉这么有特点的数大概是需要分块维护的吧

但是并没有什么区间查询,只是在最后输出整个序列

于是我们就直接用线段树维护

设置两个标记\(tag[0],tag[1]\),分别表示对应区间的最小值和最大值

初始值我们分别设成\(-inf\)和\(inf\)

之后我们分别维护就好了

如果是\(1\)操作我们要把区间的最小值更新,但是如果原来区间的最小值大于当前的值,那么就不更新

同时如果这个区间的最大值比需要更新的值还小,那么最大值也一起更新

操作\(2\)还有标记下放同理

代码

#include<iostream>
#include<cstring>
#include<cstdio>
#define re register
#define maxn 2000005
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
#define INF 100002
int l[maxn<<2],r[maxn<<2],tag[2][maxn<<2];
int n,Q;
void write(int x)
{
if(x>9) write(x/10);
putchar(x%10+48);
}
inline int read()
{
char c=getchar();
int x=0;
while(c<'0'||c>'9') c=getchar();
while(c>='0'&&c<='9')
x=(x<<3)+(x<<1)+c-48,c=getchar();
return x;
}
void build(int x,int y,int i)
{
l[i]=x,r[i]=y;
if(x==y) return;
int mid=x+y>>1;
build(x,mid,i<<1),build(mid+1,y,i<<1|1);
tag[1][i]=INF,tag[0][i]=-INF;
}
inline void pushdown(int i)
{
if(tag[0][i]!=-INF)
{
tag[0][i<<1]=max(tag[0][i],tag[0][i<<1]);
tag[1][i<<1]=max(tag[1][i<<1],tag[0][i]);
tag[0][i<<1|1]=max(tag[0][i],tag[0][i<<1|1]);
tag[1][i<<1|1]=max(tag[1][i<<1|1],tag[0][i]);
tag[0][i]=-INF;
}
if(tag[1][i]!=INF)
{
tag[1][i<<1]=min(tag[1][i],tag[1][i<<1]);
tag[0][i<<1]=min(tag[0][i<<1],tag[1][i]);
tag[1][i<<1|1]=min(tag[1][i<<1|1],tag[1][i]);
tag[0][i<<1|1]=min(tag[0][i<<1|1],tag[1][i]);
tag[1][i]=INF;
}
}
void change(int op,int val,int x,int y,int i)
{
if(x<=l[i]&&y>=r[i])
{
if(op)
{
if(val<tag[op][i]) tag[op][i]=val;
if(tag[0][i]>val) tag[0][i]=val;
}
if(!op)
{
if(val>tag[op][i]) tag[op][i]=val;
if(tag[1][i]<val) tag[1][i]=val;
}
return;
}
pushdown(i);
int mid=l[i]+r[i]>>1;
if(y<=mid) change(op,val,x,y,i<<1);
else if(x>mid) change(op,val,x,y,i<<1|1);
else change(op,val,x,y,i<<1),change(op,val,x,y,i<<1|1);
}
void print(int i)
{
if(l[i]==r[i])
{
write(tag[0][i]);
putchar(10);
return;
}
pushdown(i);
print(i<<1);
print(i<<1|1);
}
int main()
{
n=read(),Q=read();
build(0,n-1,1);
int opt,x,y,h;
while(Q--)
{
opt=read(),x=read(),y=read(),h=read();
change(opt-1,h,x,y,1);
}
print(1);
return 0;
}

【[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. P4560 [IOI2014]Wall 砖墙

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

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

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

  6. [IOI2014]Wall

    [IOI2014]Wall 题目大意: 给你一个长度为\(n(n\le2\times10^6)\)的数列,初始全为\(0\).\(m(m\le5\times10^5)\)次操作,每次让区间\([l_i ...

  7. 「IOI2014」Wall 砖墙

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

  8. BZOJ4364:[IOI2014]Wall

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

  9. bzoj AC倒序

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

随机推荐

  1. 0/1背包问题(DP)

    Description 给定 n 个物品和一个背包.物品 i 的重量是 wi ,其价值为 vi ,背包的容量为 C .问:应该如何选择装入背包的物品,使得装入背包中物品的总价值最大? Input 输入 ...

  2. 【转】Java Spring AOP详解

    一.前言 在以前的项目中,很少去关注spring aop的具体实现与理论,只是简单了解了一下什么是aop具体怎么用,看到了一篇博文写得还不错,就转载来学习一下,博文地址:http://www.cnbl ...

  3. ASP.NET之Jquery入门级别

    1.Jquery的简单介绍 1)Jquery由美国人John Resig创建.是继prototype之后又一个优秀的JavaScript框架. 2)JQuery能做什么?JQuery能做的普通的Dom ...

  4. springboot在阿里CentOS 7后台永久运行

    查看Java进程可以使用 ps -ef|grep java 首次后台永久启动,会把日志输出到新建的log.file文件 nohup java -jar demo-0.0.1-SNAPSHOT.jar ...

  5. K:单例模式中存在的问题

      对于单例模式的实现,无论其是否具有懒加载的功能,我们的目标是有且仅生成一个对象.但是,实际上,对于单例模式的一般实现,都会存在着以下的两个问题: 序列化攻击: 对于枚举方式实现的单例模式,并不存在 ...

  6. Redis实现分布式锁2

    redisTemplate实现分布式锁 /** * 分布式锁-加锁 * @param key * @param value 当前时间+超时时间 System.currentTimeMillis()+t ...

  7. qt5.6.3下使用firebird

    有人把firebird比作数据库界的瑞士军刀,想学习一下其在QT5.6中的使用,于是便开始了一场自己挖坑,自己埋的旅程. 环境说明:win7 64位+QT5.6 mingw4.9 32位(好像官网上也 ...

  8. 【javascript】javasrcipt设计模式之状态模式

    使用场景 解决多个[ifelse]嵌套,将其封装成若干个方法 区分事物内部的状态,事物内部的状态的改变往往会带来事物的行为的改变 简单的多个状态直接切换的时候 //两个状态之间的切换,使用if-els ...

  9. 微服务架构之spring cloud gateway

    Spring Cloud Gateway是spring cloud中起着非常重要的作用,是终端调用服务的入口,同时也是项目中每个服务对外暴露的统一口径,我们可以在网关中实现路径映射.权限验证.负载均衡 ...

  10. [算法练习]Excel Sheet Column Title

    题目: Given a positive integer, return its corresponding column title as appear in an Excel sheet. For ...