刷题总结——旅馆(bzoj1593线段树)
题目:
Description
奶牛们最近的旅游计划,是到苏必利尔湖畔,享受那里的湖光山色,以及明媚的阳光。作为整个旅游的策划者和负责人,贝茜选择在湖边的一家著名的旅馆住宿。这个巨大的旅馆一共有N (1 <= N <= 50,000)间客房,它们在同一层楼中顺次一字排开,在任何一个房间里,只需要拉开窗帘,就能见到波光粼粼的湖面。 贝茜一行,以及其他慕名而来的旅游者,都是一批批地来到旅馆的服务台,希望能订到D_i (1 <= D_i <= N)间连续的房间。服务台的接待工作也很简单:如果存在r满足编号为r..r+D_i-1的房间均空着,他就将这一批顾客安排到这些房间入住;如果没有满足条件的r,他会道歉说没有足够的空房间,请顾客们另找一家宾馆。如果有多个满足条件的r,服务员会选择其中最小的一个。 旅馆中的退房服务也是批量进行的。每一个退房请求由2个数字X_i、D_i 描述,表示编号为X_i..X_i+D_i-1 (1 <= X_i <= N-D_i+1)房间中的客人全部离开。退房前,请求退掉的房间中的一些,甚至是所有,可能本来就无人入住。 而你的工作,就是写一个程序,帮服务员为旅客安排房间。你的程序一共需要处理M (1 <= M < 50,000)个按输入次序到来的住店或退房的请求。第一个请求到来前,旅店中所有房间都是空闲的。
Input
* 第1行: 2个用空格隔开的整数:N、M
* 第2..M+1行: 第i+1描述了第i个请求,如果它是一个订房请求,则用2个数字 1、D_i描述,数字间用空格隔开;如果它是一个退房请求,用3 个以空格隔开的数字2、X_i、D_i描述
Output
* 第1..??行: 对于每个订房请求,输出1个独占1行的数字:如果请求能被满足 ,输出满足条件的最小的r;如果请求无法被满足,输出0
Sample Input
1 3
1 3
1 3
1 3
2 5 5
1 6
Sample Output
4
7
0
5
HINT
题解:
线段树维护区间连续最大值,区间左端点连续值,区间右端点连续值即可·····
我这里tag标记打了两个··一个订房一个退房···注意在打其中一个标记时把另外一个标记清空·····
代码:
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<ctime>
#include<cctype>
#include<cstring>
#include<string>
#include<algorithm>
using namespace std;
const int N=5e4+;
int n,m,trle[N*],trri[N*],trmx[N*],tagclear[N*],tagfull[N*];
inline int R()
{
char c;int f=;
for(c=getchar();c<''||c>'';c=getchar());
for(;c<=''&&c>='';c=getchar())
f=(f<<)+(f<<)+c-'';
return f;
}
inline void update(int k,int l,int r,int mid)
{
if(trle[k*]==(mid-l+)) trle[k]=trle[k*]+trle[k*+];
else trle[k]=trle[k*];
if(trri[k*+]==(r-mid)) trri[k]=trri[k*+]+trri[k*];
else trri[k]=trri[k*+];
trmx[k]=max(max(trmx[k*],trmx[k*+]),trri[k*]+trle[k*+]);
}
inline void build(int k,int l,int r)
{
if(l==r) {trle[k]=trri[k]=trmx[k]=;return;}
int mid=(l+r)/;
build(k*,l,mid);build(k*+,mid+,r);
update(k,l,r,mid);
}
inline void pushdown(int k,int l,int r,int mid)
{
if(tagfull[k])
{
trle[k*]=trri[k*]=trmx[k*]=mid-l+;tagfull[k*]=true;tagclear[k*]=false;
trle[k*+]=trri[k*+]=trmx[k*+]=r-mid;tagfull[k*+]=true;tagclear[k*+]=false;
tagfull[k]=false;
}
if(tagclear[k])
{
trle[k*]=trri[k*]=trmx[k*]=trle[k*+]=trri[k*+]=trmx[k*+]=;
tagclear[k*]=tagclear[k*+]=true;tagfull[k*]=tagfull[k*+]=false;
tagclear[k]=false;
}
}
inline void full(int k,int l,int r,int x,int y)
{
if(l>=x&&r<=y)
{
trle[k]=trri[k]=trmx[k]=r-l+;tagfull[k]=true;tagclear[k]=false;return;
}
int mid=(l+r)/;pushdown(k,l,r,mid);
if(x<=mid) full(k*,l,mid,x,y);
if(y>mid) full(k*+,mid+,r,x,y);
update(k,l,r,mid);
}
inline void clear(int k,int l,int r,int x,int y)
{
if(l>=x&&r<=y)
{
trle[k]=trri[k]=trmx[k]=;tagclear[k]=true;tagfull[k]=false;return;
}
int mid=(l+r)/;pushdown(k,l,r,mid);
if(x<=mid) clear(k*,l,mid,x,y);
if(y>mid) clear(k*+,mid+,r,x,y);
update(k,l,r,mid);
}
inline int find(int k,int l,int r,int x)
{
int mid=(l+r)/;
pushdown(k,l,r,mid);
if(trle[k]>=x)
{
clear(,,n,l,l+x-);return l;
}
else if(trmx[k*]>=x) return find(k*,l,mid,x);
else if(trri[k*]+trle[k*+]>=x)
{
int temp=mid-trri[k*]+;
clear(,,n,mid-trri[k*]+,mid-trri[k*]+x);
return temp;
}
else if(trmx[k*+]>=x) return find(k*+,mid+,r,x);
else if(trri[k]>=x)
{
clear(,,n,r-x+,r);return r-x+;
}
}
int main()
{
//freopen("a.in","r",stdin);
n=R(),m=R();
build(,,n);int op,a,b;
while(m--)
{
op=R();
if(op==)
{
a=R();
if(trmx[]<a) printf("0\n");
else printf("%d\n",find(,,n,a));
}
if(op==)
{
a=R(),b=R();
full(,,n,a,a+b-);
}
}
return ;
}
刷题总结——旅馆(bzoj1593线段树)的更多相关文章
- 刷题向》关于线段树的区间开根号 BZOJ3211(NORMAL+)
这是一道关于线段树的区间开根号的裸题,没什么好讲的. 值得注意的是,因为有区间开根号的性质,所以我们每一次更改操作只能把更改区间所覆盖的所有元素全部查找,当然你直接找效率明显爆炸... 能够注意到,指 ...
- BZOJ_3038_上帝造题的七分钟2_线段树
BZOJ_3038_上帝造题的七分钟2_线段树 题意: XLk觉得<上帝造题的七分钟>不太过瘾,于是有了第二部. "第一分钟,X说,要有数列,于是便给定了一个正整数数列. 第二分 ...
- 2018.06.29 NOIP模拟 旅馆(线段树)
旅馆 [问题描述] OIEROIEROIER 们最近的旅游计划,是到长春净月潭,享受那里的湖光山色,以及明 媚的阳光.你作为整个旅游的策划者和负责人,选择在潭边的一家著名的旅馆住 宿.这个巨大的旅馆一 ...
- Hotel 旅馆, 线段树查询,合并
C. Hotel 旅馆 内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 题目描述 OIER最近的旅游计划,是到长春净月潭,享受那里的湖光山色, ...
- 【刷题】BZOJ 4817 [Sdoi2017]树点涂色
Description Bob有一棵n个点的有根树,其中1号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路 径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜色. ...
- bzoj 3779 重组病毒 好题 LCT+dfn序+线段树分类讨论
题目大意 1.将x到当前根路径上的所有点染成一种新的颜色: 2.将x到当前根路径上的所有点染成一种新的颜色,并且把这个点设为新的根: 3.查询以x为根的子树中所有点权值的平均值. 分析 原题codec ...
- jzoj5986. 【WC2019模拟2019.1.4】立体几何题 (权值线段树)
传送门 题面 题解 不难看出每个点的大小为行列限制中较小的那一个(因为数据保证有解) 对于行的每个限制,能取到的个数是列里限制大于等于它的数的个数,同理,对于列是行里大于它的个数(这里没有等于,为了避 ...
- Bzoj3038 上帝造题的七分钟2 线段树
Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 1135 Solved: 509 Description XLk觉得<上帝造题的七分钟>不太 ...
- B3038 上帝造题的七分钟2 线段树
这就是一道变得比较奇怪的线段树,维护每个区间的最大值和区间和,然后关键在于每次取根号的话数值下降的特别快,不用几次就都是1了,所以每次暴力单点修改,然后直接找区间最大值,假如区间最大值是1的话,就直接 ...
随机推荐
- 怎么在WEBSTORM中设置代码模板 Live Templates
怎么在WEBSTORM中设置代码模板 Live Templates setting 里面 https://www.cnblogs.com/xinzaimengzai/p/9938464.html
- Python -- 函数之推导式
5.12 推导式 l = [] for i in range(1,11): l.append(i) print(l) # 用列表推导式 (一行搞定) l = [i for i in range(1,1 ...
- java基础—java制作证书的工具keytool
一.keytool的概念 keytool 是个密钥和证书管理工具.它使用户能够管理自己的公钥/私钥对及相关证书,用于(通过数字签名)自我认证(用户向别的用户/服务认证自己)或数据完整性以及认证服务.在 ...
- 01_13_Struts_默认Action
01_13_Struts_默认Action 1. 配置struts默认Action <package name="default" namespace="/&quo ...
- UI Testing in Xcode 7
参考文章: UI Testing in Xcode - WWDC 2015https://developer.apple.com/videos/play/wwdc2015-406/ Document ...
- Caesars Cipher-freecodecamp算法题目
Caesars Cipher(凯撒密码.移位密码) 要求 字母会按照指定的数量来做移位. 一个常见的案例就是ROT13密码,字母会移位13个位置.由'A' ↔ 'N', 'B' ↔ 'O',以此类推. ...
- NOIP2018 - 一些板子
好多东西都不熟练…… 数论 数论分块「bzoj2956: 模积和」 10.28.2018 #include<bits/stdc++.h> typedef long long ll; ; ; ...
- MyBatis的mapper.xml文件的参数问题:org.apache.ibatis.builder.IncompleteElementException: Could not find parameter map
配置参数类型有两种选择,即:parameterType和parameterMap 不管参数是否是基本数据类型还是map类型,都是使用parameterType. 版权声明:本文为博主原创文章,未经博主 ...
- JS处理数据四舍五入,tofixed与round的区别
此区别是在做微信端有关绑定设备数据曲线平滑处理的过程中,进行验证时候无意发现. 1 .tofixed方法 toFixed() 方法可把 Number 四舍五入为指定小数位数的数字.例如将数据Num保留 ...
- day22-python之模块
1.os import os # print(os.getcwd()) # os.chdir("..") # print(os.getcwd()) # os.makedirs('d ...