hdu1540
怎么会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的更多相关文章
- hdu-1540线段树刷题
title: hdu-1540线段树刷题 date: 2018-10-18 19:55:21 tags: acm 刷题 categories: ACM-线段树 概述 哇,,,这道线段树的题可以说是到目 ...
- HDU1540 Tunnel Warfare —— 线段树 区间合并
题目链接:https://vjudge.net/problem/HDU-1540 uring the War of Resistance Against Japan, tunnel warfare w ...
- 最大连续区间(HDU-1540)
HDU1540 线段树最大连续区间. 给定长度为n的数组,m次操作. 操作D,删除给定节点. 操作R,恢复最后一个删除的节点. 操作Q,询问给定节点的最大连续区间 维护三个值,区间的最大左连续区间,最 ...
- hdu1540 Tunnel Warfare
Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)To ...
- HDU1540 Tunnel Warfare 水题
分析:不需要线段树,set可过,STL大法好 #include <iostream> #include <cstdio> #include <cstring> #i ...
- hdu1540之线段树单点更新+区间合并
Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) T ...
- hdu1540(线段树)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1540 题意:是一条线上的点,D x是破坏这个点,Q x是表示查询以x所在的最长的连续的点的个数,R是恢 ...
- hdu1540线段树
https://vjudge.net/contest/66989#problem/I #include<iostream> #include<cstdio> #include& ...
- hdu1540 区间操作,合并,模板题
During the War of Resistance Against Japan, tunnel warfare was carried out extensively in the vast a ...
- HDU--1540 Tunnel Warfare(线段树区间更新)
题目链接:1540 Tunnel Warfare 以为单组输入 这个题多组输入 结构体记录每个区间左边和右边的连续区间 ms记录最大 在查询操作时: 1.这个点即将查询到右区间 看这个点 x 是否存在 ...
随机推荐
- 【已解决】Microsoft visual c++ 14.0 is required问题解决办法
装 识别图形验证码库tesserocr的时候,出现了Microsoft visual c++ 14.0 is required的问题,用离线安装还是没有用. 就只能乖乖装Microsoft visua ...
- go 数组与切片
数组概念 1.数组:是同一种数据类型的固定长度的序列. 2.数组定义:var a [len]int,比如:var a[5]int,一旦定义,长度不能变 3.长度是数组类型的一部分,因此,var a[5 ...
- 微信接口开发之高级篇系列【微信JS-SDK】
PHP微信公众平台开发高级篇—微信JS-SDK 第一步.绑定域名: 第二步.引入JS文件: 第三部.通过Config接口注入权限验证配置 第四部.通过Read接口处理成功验证 第五部.通过Error接 ...
- TwemProxy Redis架构
TwemProxy 1.twemproxy是twitter开发的一个redis代理proxy. 通过Twemproxy可以使用多台服务器来水平扩张redis服务,可以有效的避免redis单点故障问题. ...
- 日期与时间控件QDate, QTime, QDateTime
QDate类用于处理公历日期.QTime类用于处理时间.QDateTime类将QDate对象和QTime对象整合为一个对象 QDate: from PyQt5.QtCore import QDate, ...
- js设置按钮不可用
<input type="button" value="确定" id="stamp" onclick="stampBill( ...
- Educational Codeforces Round 47 (Rated for Div. 2) 题解
题目链接:http://codeforces.com/contest/1009 A. Game Shopping 题目: 题意:有n件物品,你又m个钱包,每件物品的价格为ai,每个钱包里的前为bi.你 ...
- python初步学习-import和datetime模块
模块 一个完整大型的python程序是由模块和包的形式组织起来的,可见模块在python中的重要性.模块是一种组织型式,它许多有关联(关系)的代码组织放到单独的独立文件中.简单的说,可以把模块理解为一 ...
- ResNet152网络复现(Caffe)
一.准备数据集 1) 下载数据集 Imagnet网站上下载了三类图片,分别是big cat.dog.fish,其中训练集的图片数一共是4149,测试集的图片数是1003,训练集和测试集的图片数比例4 ...
- CMake 实践教程
本篇博客是根据 <<CMake Practice>> 一文编写, 目的有三: 其一: 提取出其中的精要部分; 其二: 对其中不易理解的地方进行简要说明; 其三: 方便后续查找复 ...