BZOJ 1593: [Usaco2008 Feb]Hotel 旅馆 [线段树]
题意:
操作1:找长为$len$的空区间并填满,没有输出$0$
操作2:将$[l,r]$之间的区间置空
我真是太弱了这种线段树还写了一个半小时,中间为了查错手动模拟了$30min$线段树操作,然后发现$zz$的寻找时没有单独判断跨过中间的情况,自以为看一下$t[x].pos$就可以了...
然后交到洛谷$T$了一个点,交到$BZOJ$跑了$7s$度人家都是不到半秒,突然发现自己的寻找是$nlogn$的......然后改成$logn$又出了点小问题无奈加上了判断$l==r$.....我太弱了
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std;
#define lc x<<1
#define rc x<<1|1
#define mid ((l+r)>>1)
#define lson lc,l,mid
#define rson rc,mid+1,r
const int N=1e5+,INF=1e9;
typedef long long ll;
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x*f;
} int n,Q,op,p,len;
struct Node{
int mx,lm,rm,pos,rpos;
int tag;
Node():mx(),lm(),rm(){}
void debug(){printf("%d %d %d %d %d %d\n",mx,lm,rm,pos,rpos,tag);}
}t[N<<]; inline void merge(int x,int l,int r){
if(t[lc].mx>t[rc].mx)
t[x].mx=t[lc].mx,t[x].pos=t[lc].pos;
else t[x].mx=t[rc].mx,t[x].pos=t[rc].pos;
if(t[lc].rm+t[rc].lm>t[x].mx) t[x].mx=t[lc].rm+t[rc].lm,t[x].pos=t[lc].rpos; if(t[lc].lm==mid-l+) t[x].lm=t[lc].lm+t[rc].lm;
else t[x].lm=t[lc].lm;
if(t[rc].rm==r-mid&&t[lc].rm)
t[x].rm=t[rc].rm+t[lc].rm,t[x].rpos=t[lc].rpos;
else t[x].rm=t[rc].rm, t[x].rpos=t[rc].rpos;
} inline void paint(int x,int l,int r,int v){
t[x].tag=v;
if(v==) t[x].mx=t[x].lm=t[x].rm=,t[x].pos=t[x].rpos=INF;
else t[x].mx=t[x].lm=t[x].rm=r-l+,t[x].pos=t[x].rpos=l;
}
inline void pushDown(int x,int l,int r){
if(t[x].tag){
paint(lson,t[x].tag);
paint(rson,t[x].tag);
t[x].tag=;
}
}
void build(int x,int l,int r){
if(l==r) t[x].mx=t[x].lm=t[x].rm=,t[x].pos=t[x].rpos=l;
else{
build(lson);
build(rson);
merge(x,l,r);
}
//printf("build %d %d %d \n",x,l,r);
//t[x].debug();
} void segAdd(int x,int l,int r,int ql,int qr,int v){//printf("segAdd %d %d %d\n",x,l,r);
if(ql<=l&&r<=qr) paint(x,l,r,v);
else{
pushDown(x,l,r);
if(ql<=mid) segAdd(lson,ql,qr,v);
if(mid<qr) segAdd(rson,ql,qr,v);
merge(x,l,r);
}
//printf("segAdd %d %d %d\n",x,l,r);
//t[x].debug();
} int segFin(int x,int l,int r,int len){//printf("segFin %d %d %d %d %d\n",x,l,r,len,t[x].mx);
if(l==r) return l;
if(t[x].mx<len) return INF;
else{
pushDown(x,l,r);
if(t[lc].mx>=len) return segFin(lson,len);
else if(t[lc].rm+t[rc].lm>=len&&t[lc].rm) return t[lc].rpos;
else return segFin(rson,len);
}
} inline void Query1(int len){
if(t[].mx<len) puts("");
else{
int ans=segFin(,,n,len);
printf("%d\n",ans);
segAdd(,,n,ans,ans+len-,);//printf("ql qr %d %d\n",ans,ans+len-1);
}
}
inline void Query2(int ql,int qr){
segAdd(,,n,ql,qr,-);
} int main(){
freopen("in","r",stdin);
//freopen("out","w",stdout);
n=read();Q=read();
build(,,n);
for(int id=;id<=Q;id++){//printf("Q %d %d\n",id,t[1<<1].mx);
op=read();
if(op==) len=read(),Query1(len);
else p=read(),len=read(),Query2(p,p+len-);
}
}
BZOJ 1593: [Usaco2008 Feb]Hotel 旅馆 [线段树]的更多相关文章
- bzoj1593 [Usaco2008 Feb]Hotel 旅馆(线段树)
1593: [Usaco2008 Feb]Hotel 旅馆 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 758 Solved: 419[Submit ...
- bzoj 1593: [Usaco2008 Feb]Hotel 旅馆【线段树】
参考:https://blog.csdn.net/u010336344/article/details/53034372 神一样的线段树 线段树上维护:ll从左开始最长空段:rr从右开始最长空段:le ...
- 【bzoj1593】[Usaco2008 Feb]Hotel 旅馆 线段树区间合并
题目描述 奶牛们最近的旅游计划,是到苏必利尔湖畔,享受那里的湖光山色,以及明媚的阳光.作为整个旅游的策划者和负责人,贝茜选择在湖边的一家著名的旅馆住宿.这个巨大的旅馆一共有N (1 <= N & ...
- BZOJ 1593: [Usaco2008 Feb]Hotel 旅馆
Description 奶牛们最近的旅游计划,是到苏必利尔湖畔,享受那里的湖光山色,以及明媚的阳光.作为整个旅游的策划者和负责人,贝茜选择在湖边的一家著名的旅馆住宿.这个巨大的旅馆一共有N (1 &l ...
- 1593: [Usaco2008 Feb]Hotel 旅馆
1593: [Usaco2008 Feb]Hotel 旅馆 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 391 Solved: 228[Submit ...
- 【BZOJ】1593: [Usaco2008 Feb]Hotel 旅馆
[算法]线段树(经典线段树上二分) [题意]n个房间,m个询问,每次订最前的连续x个的空房间,或退订从x开始y个房间,求每次订的最左房间号. [题解]关键在于找连续x个空房间,经典二分. 线段树标记s ...
- 线段树||BZOJ1593: [Usaco2008 Feb]Hotel 旅馆||Luogu P2894 [USACO08FEB]酒店Hotel
题面:P2894 [USACO08FEB]酒店Hotel 题解:和基础的线段树操作差别不是很大,就是在传统的线段树基础上多维护一段区间最长的合法前驱(h_),最长合法后驱(t_),一段中最长的合法区间 ...
- 【最长连续零 线段树】bzoj1593: [Usaco2008 Feb]Hotel 旅馆
最长连续零的线段树解法 Description 奶牛们最近的旅游计划,是到苏必利尔湖畔,享受那里的湖光山色,以及明媚的阳光.作为整个旅游的策划者和负 责人,贝茜选择在湖边的一家著名的旅馆住宿.这个巨大 ...
- BZOJ1593 [Usaco2008 Feb]Hotel 旅馆
裸上线段树,就是记的东西有点多... 每个点记区间左端最长0,右端最长0,中间最长0,和tag表示是否全为0/1 直接更新就好,查询的时候先查左儿子,然后查中间,最后查右儿子... /******** ...
随机推荐
- Shell菜单脚本
今天在这儿给大家分享一个我简单编写的Shell菜单脚本,傻瓜式的人机交互,人人都可以操作linux. #!/bin/sh #Shell菜单演示 function menu () { cat <& ...
- [国嵌笔记][021-022][ARM处理器工作模式]
[ARM处理器工作模式] 处理器工作模式 1.User(urs):用户模式,linux应用程序运行在用户模式 2.FIQ(fiq):快速中断模式 3.IRQ(irq):中断模式 4.Superviso ...
- bat脚本设置系统环境变量即时生效
关于bat的资料多但零碎,记录一下. 1.设置环境变量即时生效:通过重启explorer来实现即时生效(亲测有效) @echo off set curPath=%cd% wmic ENVIRONMEN ...
- 如何用SVN版本控制器将提交的文件还原到以前的版本
工具/原料 SVN乌龟软件和相关的文件 方法/步骤 在相关的文件中右击鼠标,按右图进行选择 在弹出框的地方点击我标记的地方,查看下曾经提交过的版本文件 在弹出框的地方,上面就是有版本号,下面就是我们文 ...
- Java读书推荐
想要深入掌握一门技术,读书是必不可少的一步,也是最重要的一步.有些书需要读很多遍才能深入理解,经过几本甚至几十本书的熏陶,才能让你在这个行业中越走越远,爱上这个行业,抽出时间多读本书吧,读书会让人如虎 ...
- 【开发技术】web.xml vs struts.xml
web.xml用来配置servlet,监听器(Listener),过滤器(filter),还有404错误跳转页面,500,等还配置欢迎页面等,总之一句话,就是系统总配置方案写在web.xml中 str ...
- servlet多线程问题
Servlet本身是单实例的,这样当多个用户同时访问某个Servlet时,会访问该唯一的Servlet实例中的成员变量,如果对成员变量进行写入工作,那就会导致Servlet的多线程问题,即数据不一致. ...
- uwsgi wsgi nginx centos7.2部署flask
请原谅我比较懒,直接粘贴onenote笔记了 方法一测试完成后,建议用方法三:uwsgi,ginx部署
- C#总结(四)调用C++动态库
由于公司很多底层的SDK,都是C++开发,上层的应用软件却是C# Winform程序.在实际工作的过程中,就经常碰到了C# 程序调用C++ 动态库的问题.最近一直在和C++ 打交道,C# 怎么调用C+ ...
- ASP.net core 2.0.0 中 asp.net identity 2.0.0 的基本使用(三)—用户账户及cookie配置
修改用户账户及cookie配置 一.修改密码强度和用户邮箱验证规则: 打开Startup.cs,找到public void ConfigureServices(IServiceCollection s ...