怎么会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. spring @Transactional注解参数详解

    事物注解方式: @Transactional 当标于类前时, 标示类中所有方法都进行事物处理 , 例子: @Transactional public class TestServiceBean imp ...

  2. Hive记录-配置客户端可视化管理工具远程连接

    配置客户端远程连接(方便可视化工具操作)-不需要在hive服务器上敲命令了 1.安装DBeaver工具:https://dbeaver.com/download/ 2.准备相关驱动文件(服务器上hiv ...

  3. ruby where用法

    用法1 Subject.where(").order("name") 用法2 与find方法不同的是,where方法返回的结果不是数组而是ActiveRelation,这 ...

  4. AES加密【转】

    .   此时就一定要使用如下代码步骤 : 1.SecureRandom的key定下来. SecureRandom 实现完全隨操作系统本身的內部狀態,除非調用方在調用 getInstance 方法之後又 ...

  5. Java NIO 机制分析(一) Java IO的演进

    一.引言 Java1.4之前的早期版本,Java对I/O的支持并不完善,开发人员再开发高性能I/O程序的时候,会面临一些巨大的挑战和困难,主要有以下一些问题: (1)没有数据缓冲区,I/O性能存在问题 ...

  6. error: control may reach end of non-void function [-Werror,-Wreturn-type]

    编译出现如下错误 error: control may reach end of non-void function [-Werror,-Wreturn-type] 这个错误可能和编译器有关(在相同代 ...

  7. Python异常处理和进程线程-day09

    写在前面 上课第九天,打卡: 最坏的结果,不过是大器晚成: 一.异常处理 - 1.语法错误导致的异常 - 这种错误,根本过不了python解释器的语法检测,必须在程序运行前就修正: - 2.逻辑上的异 ...

  8. linux系统--用户和用户组

    一.用户和用户组的概念 用户:使用操作系统的人 用户组:具有相同系统权限的一组用户.在linux系统中可以存在多个用户组 1.1 /etc/group 这里存储当前系统中所有用户组的信息 每一行对应一 ...

  9. javaScript事件系统详解

    一个有情怀的猴子

  10. python - 远程主机执行命令练习(socket UDP + subprocess.Popen()) 练习1

    环境是windows 环境. server端: import socket import subprocess ss = socket.socket(socket.AF_INET,socket.SOC ...