怎么会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. Docker mysql主主互备和高可用

    一.测试环境 1.1 结构图 1.2 版本 操作系统:CentOS 7.3 MySQL版本:5.6.35 Docker版本:18.06.1-ce 使用root用户操作 IP地址说明 IP地址 用途 备 ...

  2. brctl创建虚拟网卡详解

    brctl创建虚拟网卡详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 很久之前我分享过一篇关于搭建Openvpn的笔记,在笔记的最后我分享了一个脚本,是用来创建虚拟网卡的,今天 ...

  3. HTML的前世今生

    HTML的基础知识扫盲 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 三年前,我就听周围的一些工程师说,python就是一个脚本语言,没啥好学的,学JAVA吧,python能干的J ...

  4. <!--more-->搭建的博客设置主页内容高度

    用 markdown写文章时插入<!--more-->,文章会自动从插入的位置截断,也就是说在博客中只显示<!--more-->之前的内容,点击阅读全文之后会显示所有内容.

  5. spyder里的"查找文件里的特定字符串"非常方便

    spyder里的"查找文件里的特定字符串"非常方便 快捷键是: ^+shift+F 使用方法: 输入被查找的字符串: 比如: .rcParam, 注意大小写敏感的(默认设置) 回车 ...

  6. u-boot移植(十三)---代码修改---裁剪及环境变量 二

    一.错误处理 上一节遇到一个错误: print一下: 发现我们在jz2440.h中静态写的网络参数都没有写进去. dm9000 address not set. dm9000的地址未设置. 这里对应两 ...

  7. LeetCode -Reverse Pairs

    my solution: class Solution { public: int reversePairs(vector<int>& nums) { int length=num ...

  8. luogu P1762 偶数

    打表找规律吼题哇 首先打出\(1-1000\)内的答案的表 0 0 1 1 4 6 9 9 16 ... 448363 ~~有个**规律啊qwq~~ 然后想到用\(\frac{n(n+1)}{2}\) ...

  9. Linux监控工具Spotlight on Unix

    1.介绍 Spotlight on Unix是一款Linux系统运行状况的监控工具,可以安装在Windows下,监控Linux服务器的运行状况. 监控项目包括:CPU.内存.交换空间.虚拟内存等的使用 ...

  10. php 设置中文 cookie, js获取

    参考链接:http://www.nowamagic.net/librarys/veda/detail/1271 http://www.ruanyifeng.com/blog/2008/06/base6 ...