怎么会T啊

/*
三种操作:D x:第x个位置1
Q x:查询第x位置所在的0连续块
R :将上次D的位置置0
*/
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
using namespace std;
#define maxn 50050
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
int lmx[maxn<<],rmx[maxn<<],mx[maxn<<];
int des[maxn],top; inline void pushup(int l,int r,int rt){
lmx[rt]=lmx[rt<<];
rmx[rt]=rmx[rt<<|];
mx[rt]=max(mx[rt<<],mx[rt<<|]); int m=l+r>>;
if(lmx[rt<<]==m-l+) lmx[rt]=m-l++lmx[rt<<|];
if(rmx[rt<<|]==r-l) rmx[rt]=r-m+rmx[rt<<];
mx[rt]=max(mx[rt],rmx[rt<<]+lmx[rt<<|]);
}
void build(int l,int r,int rt){
if(l==r){
lmx[rt]=rmx[rt]=mx[rt]=;
return;
}
int m=l+r>>;
build(lson);
build(rson);
pushup(l,r,rt);
}
void update(int pos,int c,int l,int r,int rt){
if(l==r){
lmx[rt]=rmx[rt]=mx[rt]=c;
return;
}
int m=l+r>>;
if(pos<=m) update(pos,c,lson);
else if(pos>m) update(pos,c,rson);
pushup(l,r,rt);
}
int query(int pos,int l,int r,int rt){
if(mx[rt]== || l==r || mx[rt]==r-l+)
return mx[rt]; int m=l+r>>;
if(pos<=m){
if(pos>=m-rmx[rt<<]+)
return query(pos,lson)+query(m+,rson);
else return query(pos,lson);
}
else {
if(pos<=m+lmx[rt<<|])
return query(pos,rson)+query(m,lson);
else return query(pos,rson);
}
}
int main(){
int n,m;
while(scanf("%d%d",&n,&m)!=EOF){
memset(des,,sizeof des);
top=;
build(,n,); char op[];
int a,b;
while(m--){
scanf("%s",op);
if(op[]=='D'){
scanf("%d",&a);
update(a,,,n,);
des[top++]=a;
}
else if(op[]=='Q'){
scanf("%d",&a);
printf("%d\n",query(a,,n,));
}
else {
int tmp=des[--top];
update(tmp,,,n,);
}
}
}
return ;
}

ac代码

/*
三种操作:D x:第x个位置1
Q x:查询第x位置所在的0连续块
R :将上次D的位置置0
*/
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
using namespace std;
#define maxn 50050
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
int lmx[maxn<<],rmx[maxn<<],mx[maxn<<];
int des[maxn],top; inline void pushup(int l,int r,int rt){
lmx[rt]=lmx[rt<<];
rmx[rt]=rmx[rt<<|];
mx[rt]=max(mx[rt<<],mx[rt<<|]); int m=l+r>>;
if(lmx[rt<<]==m-l+) lmx[rt]=m-l++lmx[rt<<|];
if(rmx[rt<<|]==r-m) rmx[rt]=r-m+rmx[rt<<];
mx[rt]=max(mx[rt],rmx[rt<<]+lmx[rt<<|]);
}
void build(int l,int r,int rt){
if(l==r){
lmx[rt]=rmx[rt]=mx[rt]=;
return;
}
int m=l+r>>;
build(lson);
build(rson);
pushup(l,r,rt);
}
void update(int pos,int c,int l,int r,int rt){
if(l==r){
lmx[rt]=rmx[rt]=mx[rt]=c;
return;
}
int m=l+r>>;
if(pos<=m) update(pos,c,lson);
if(pos>m) update(pos,c,rson);
pushup(l,r,rt);
}
int query(int pos,int l,int r,int rt){
if(mx[rt]== || l==r || mx[rt]==r-l+)
return mx[rt]; int m=l+r>>;
if(pos<=m){
if(pos+rmx[rt<<]>m)//比之前优化了
return rmx[rt<<]+lmx[rt<<|];
else return query(pos,lson);
}
else {
if(m+lmx[rt<<|]>=pos)//比之前优化了
return rmx[rt<<]+lmx[rt<<|];
else return query(pos,rson);
}
}
int main(){
int n,m;
while(scanf("%d%d",&n,&m)!=EOF){
memset(des,,sizeof des);
top=;
build(,n,); char op[];
int a,b;
while(m--){
scanf("%s",op);
if(op[]=='D'){
scanf("%d",&a);
update(a,,,n,);
des[top++]=a;
}
else if(op[]=='Q'){
scanf("%d",&a);
printf("%d\n",query(a,,n,));
}
else {
int tmp=des[--top];
update(tmp,,,n,);
}
}
}
return ;
}

hdu1540的更多相关文章

  1. hdu-1540线段树刷题

    title: hdu-1540线段树刷题 date: 2018-10-18 19:55:21 tags: acm 刷题 categories: ACM-线段树 概述 哇,,,这道线段树的题可以说是到目 ...

  2. HDU1540 Tunnel Warfare —— 线段树 区间合并

    题目链接:https://vjudge.net/problem/HDU-1540 uring the War of Resistance Against Japan, tunnel warfare w ...

  3. 最大连续区间(HDU-1540)

    HDU1540 线段树最大连续区间. 给定长度为n的数组,m次操作. 操作D,删除给定节点. 操作R,恢复最后一个删除的节点. 操作Q,询问给定节点的最大连续区间 维护三个值,区间的最大左连续区间,最 ...

  4. hdu1540 Tunnel Warfare

    Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)To ...

  5. HDU1540 Tunnel Warfare 水题

    分析:不需要线段树,set可过,STL大法好 #include <iostream> #include <cstdio> #include <cstring> #i ...

  6. hdu1540之线段树单点更新+区间合并

    Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) T ...

  7. hdu1540(线段树)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1540 题意:是一条线上的点,D x是破坏这个点,Q x是表示查询以x所在的最长的连续的点的个数,R是恢 ...

  8. hdu1540线段树

    https://vjudge.net/contest/66989#problem/I #include<iostream> #include<cstdio> #include& ...

  9. hdu1540 区间操作,合并,模板题

    During the War of Resistance Against Japan, tunnel warfare was carried out extensively in the vast a ...

  10. HDU--1540 Tunnel Warfare(线段树区间更新)

    题目链接:1540 Tunnel Warfare 以为单组输入 这个题多组输入 结构体记录每个区间左边和右边的连续区间 ms记录最大 在查询操作时: 1.这个点即将查询到右区间 看这个点 x 是否存在 ...

随机推荐

  1. transform顺序浅谈

    有用过transform的小伙伴们可能都会遇到一些问题,发现transform得到的结果往往不是我们所想的 例如scale(2,1) rotate(30deg) ,我们预想的结果是一个先放大的元素,然 ...

  2. PHP5.5+Nginx1.9

    1. 安装Nginx:http://www.cnblogs.com/vurtne-lu/p/7010065.html 2. 编译安装 [root@zabbix opt]# wget http://cn ...

  3. Jupyter 魔术命令(magic commands)

    自动重新加载更改的模块 命令参数如下所示: %autoreload: 自动重载%aimport排除的模块之外的所有模块. %autoreload 0: 禁用自动重载 %autoreload 1: 自动 ...

  4. 【官方文档】Nginx模块Nginx-Rtmp-Module学习笔记(二)HLS 指令详解

    源码地址:https://github.com/Tinywan/PHP_Experience 一.在Nginx配置文件的RTMP模块中配置hls hls_key_path /tmp/hlskeys; ...

  5. PHP 日志专题

    PHP堆栈跟踪(php stack trace) PHP message: PHP Stack trace: PHP message: PHP . {main}() PHP message: PHP ...

  6. 图标网站,IcoMoon,自己动手做一个 font

    很有用的IcoMoon,在线制作工工具:https://icomoon.io/app/#/select/font 大神解说:如何灵活利用免费开源图标字体-IcoMoon篇http://www.zhan ...

  7. JS知识整理之 Call&Apply方法

    JavaScript中的函数也是对象,和其他JS对象一样也可以包含方法,其中Call和Apply就是其中比较重要的方法,可以用来间接的调用函数.这两个方法允许显式制定调用所需的this值,也就是说所有 ...

  8. mipsel汇编指令学习

    MIPS汇编语言基础 MIPS的系统结构及设计理念比较先进,其指令系统经过通用处理器指令体系MIPS I.MIPS II.MIPS III.MIPS IV.MIPS V,以及嵌入式指令体系MIPS16 ...

  9. 时间轴QTimeLine

    一个动画由多张静态图片组成,每一张静态图片为一帧.每隔一定时间显示一帧,如果时间间隔非常短的话,那这些静态图片就会构成一个连续影像,动画由此而来.QTimeLine提供了用于控制动画的时间轴,它在实现 ...

  10. Java EE之Form的get与post方法

    Form表单中method="post/get'的区别 Form提供了两种数据传输的方式——get和post.虽然它们都是数据的提交方式,但是在实际传输时确有很大的不同,并且可能会对数据产生 ...