poj 3667 Hotel(线段树,区间合并)
Hotel
Time Limit: 3000MS
Memory Limit: 65536K
Total Submissions: 10858
Accepted: 4691
Description
The cows are journeying north to Thunder Bay in Canada to gain cultural enrichment and enjoy a vacation on the sunny shores of Lake Superior. Bessie, ever the competent travel agent, has named the Bullmoose Hotel on famed Cumberland Street as their vacation residence. This immense hotel has N (1 ≤ N ≤ 50,000) rooms all located on the same side of an extremely long hallway (all the better to see the lake, of course).
The cows and other visitors arrive in groups of size Di (1 ≤ Di ≤ N) and approach the front desk to check in. Each group i requests a set of Di contiguous rooms from Canmuu, the moose staffing the counter. He assigns them some set of consecutive room numbers r..r+Di-1 if they are available or, if no contiguous set of rooms is available, politely suggests alternate lodging. Canmuu always chooses the value of r to be the smallest possible.
Visitors also depart the hotel from groups of contiguous rooms. Checkout i has the parameters Xi and Di which specify the vacating of rooms Xi ..Xi +Di-1 (1 ≤ Xi ≤ N-Di+1). Some (or all) of those rooms might be empty before the checkout.
Your job is to assist Canmuu by processing M (1 ≤ M < 50,000) checkin/checkout requests. The hotel is initially unoccupied.
Input
* Line 1: Two space-separated integers: N and M
* Lines 2..M+1: Line i+1 contains request expressed as one of two possible formats: (a) Two space separated integers representing a check-in request: 1 and Di (b) Three space-separated integers representing a check-out: 2, Xi, and Di
Output
* Lines 1.....: For each check-in request, output a single line with a single integer r, the first room in the contiguous sequence of rooms to be occupied. If the request cannot be satisfied, output 0.
Sample Input
10 6
1 3
1 3
1 3
1 3
2 5 5
1 6
Sample Output
1
4
7
0
5
题意:告诉你有n个房间,一开始都是空房间,接下来m次操作,每一次操作,如果第一个数是1,Di就表示有人需要租Di间连续的房间,如果没有输出0,如果有则房间租出,
如果有满足条件的有种情况,则租最左边的。如果第一个数是2,则Xi、Di分别表示从Xi号房间到Xi+Di-1号房间的人退房。
::这道题我是在参考hh神的代码慢慢敲出来的,现在有些理解
房间 1 2 3 4 5 6 7 8
(1租出) 1 1 0 1 1 1 1 1
lsum表示的是区间左端开始的连续房间个数,即lsum=2;
rsum表示的是区间右端开始的连续房间个数,即rsum=5;
msum表示中间部分连续房间的最大个数,即msum=5;
代码:
1: #include <iostream>
2: #include <cstdio>
3: #include <cstring>
4: #include <algorithm>
5: #include <queue>
6: using namespace std;
7: #define lson l,m,rt<<1
8: #define rson m+1,r,rt<<1|1
9: typedef long long ll;
10: const int N=55555;
11: int lsum[N<<2],rsum[N<<2],msum[N<<2];
12: int cover[N<<2];
13:
14: void Down(int rt,int m)
15: {
16: if(cover[rt]!=-1)
17: {
18: int ls=rt<<1,rs=ls|1;
19: cover[ls]=cover[rs]=cover[rt];
20: lsum[ls]=rsum[ls]=msum[ls]=cover[rt]?0:m-(m>>1);
21: lsum[rs]=rsum[rs]=msum[rs]=cover[rt]?0:(m>>1);
22: cover[rt]=-1;
23: }
24: }
25:
26: void Up(int rt,int m)
27: {
28: lsum[rt]=lsum[rt<<1];
29: rsum[rt]=rsum[rt<<1|1];
30: if(lsum[rt]==m-(m>>1)) lsum[rt]+=lsum[rt<<1|1];
31: if(rsum[rt]==(m>>1)) rsum[rt]+=rsum[rt<<1];
32: msum[rt]=max(rsum[rt<<1]+lsum[rt<<1|1],max(msum[rt<<1],msum[rt<<1|1]));
33: }
34:
35: void build(int l,int r,int rt)
36: {
37: lsum[rt]=rsum[rt]=msum[rt]=r-l+1;
38: cover[rt]=-1;
39: if(l==r) return ;
40: int m=(l+r)>>1;
41: build(lson);
42: build(rson);
43: }
44:
45: void update(int L,int R,int c,int l,int r,int rt)
46: {
47: if(L<=l&&R>=r)
48: {
49: lsum[rt]=rsum[rt]=msum[rt]=c?0:r-l+1;
50: cover[rt]=c;
51: return ;
52: }
53: Down(rt,r-l+1);
54: int m=(l+r)>>1;
55: if(L<=m) update(L,R,c,lson);
56: if(R>m) update(L,R,c,rson);
57: Up(rt,r-l+1);
58: }
59:
60: int query(int len,int l,int r,int rt)
61: {
62: if(l==r) return l;
63: Down(rt,r-l+1);
64: int m=(l+r)>>1;
65: if(msum[rt<<1]>=len) return query(len,lson);
66: else if(rsum[rt<<1]+lsum[rt<<1|1]>=len)
67: return m-rsum[rt<<1]+1;
68: return query(len,rson);
69: }
70:
71: int main()
72: {
73: // freopen("in.txt","r",stdin);
74: int n,m;
75: while(scanf("%d%d",&n,&m)>0)
76: {
77: int c,a,b;
78: build(1,n,1);
79: while(m--)
80: {
81: scanf("%d",&c);
82: if(c==1)
83: {
84: scanf("%d",&a);
85: if(msum[1]<a) puts("0");
86: else
87: {
88: int p=query(a,1,n,1);
89: printf("%d\n",p);
90: update(p,p+a-1,1,1,n,1);
91: }
92: }
93: else
94: {
95: scanf("%d%d",&a,&b);
96: update(a,a+b-1,0,1,n,1);
97: }
98: }
99: }
100: return 0;
101: }
poj 3667 Hotel(线段树,区间合并)的更多相关文章
- POJ 3667 Hotel(线段树 区间合并)
Hotel 转载自:http://www.cnblogs.com/scau20110726/archive/2013/05/07/3065418.html [题目链接]Hotel [题目类型]线段树 ...
- POJ 3667 Hotel (线段树区间合并)
题目链接:http://poj.org/problem?id=3667 最初给你n间空房,m个操作: 操作1 a 表示检查是否有连续的a间空房,输出最左边的空房编号,并入住a间房间. 操作2 a b ...
- POJ 3667 & 1823 Hotel (线段树区间合并)
两个题目都是用同一个模板,询问最长的连续未覆盖的区间 . lazy代表是否有人,msum代表区间内最大的连续长度,lsum是从左结点往右的连续长度,rsum是从右结点往左的连续长度. 区间合并很恶心啊 ...
- poj 3667 Hotel (线段树)
http://poj.org/problem?id=3667 Hotel Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 94 ...
- 线段树(区间合并) POJ 3667 Hotel
题目传送门 /* 题意:输入 1 a:询问是不是有连续长度为a的空房间,有的话住进最左边 输入 2 a b:将[a,a+b-1]的房间清空 线段树(区间合并):lsum[]统计从左端点起最长连续空房间 ...
- Poj 3667——hotel——————【线段树区间合并】
Hotel Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 13124 Accepted: 5664 Descriptio ...
- poj3667 Hotel (线段树 区间合并)
poj3667 HotelTime Limit: 3000MS Memory Limit: 65536KTotal Submissions: 18925 Accepted: 8242Descripti ...
- 【bzoj1593】[Usaco2008 Feb]Hotel 旅馆 线段树区间合并
题目描述 奶牛们最近的旅游计划,是到苏必利尔湖畔,享受那里的湖光山色,以及明媚的阳光.作为整个旅游的策划者和负责人,贝茜选择在湖边的一家著名的旅馆住宿.这个巨大的旅馆一共有N (1 <= N & ...
- POJ 2482 Stars in Your Window (线段树区间合并+扫描线)
这题开始一直被矩形框束缚了,想法一直都是枚举线,但是这样枚举都需要O(n^2)...但是看了别人的思路,感觉这题思想真心很好(PS:开头好浪漫的描述啊,可惜并没有什么用) 题意就是在平面上给你一些星 ...
随机推荐
- Ext.NET 4.1 最新版本破解
Ext.NET 4.1 最新版本破解 今天在将Ext.NET 4.1版本的程序发布到公网时居然要license(localhost和127.0.0.1不收费),而且一年$4999,突然间觉得这是什么鬼 ...
- ASP.NET文本框密码赋默认值的方法
对于普通的文本输入框,可以使用下边的方法赋默认值: <asp:TextBox ID="TextBox1" runat="server">12345& ...
- jquery实现全选功能
主要是模拟一些网页中的表格实现全选功能. <form> 你爱好的运动是: <input type="checkbox" id="Check" ...
- win7局域网里输入正确密码也访问不了其他的机器
1.本地安全策略-本地策略-安全选项-网络安全:LAN管理器身份验证级别,默认是“没有定义”,更改为“发送LM和NTLM响应! Windows 7系统自带的是一个统安全管理工具--本地安全策略,它可以 ...
- PHP OAuth2 Server库
想找比较正宗的库,查了蛮久的.最后在 oauth官方站上,看到PHP版本的相关链接. 发现都是php 5.3版本以上的环境,基于命名空间的写法编写的. 访问下面这个页面,难得,发现文档给出了5.2版本 ...
- How Tomcat Works读书笔记之升级架构
上一篇HttpServer类职责很多,包括启动服务器,创建ServerSocket,得到客户端Socket,创建Request对象和Response对象,并解析Http请求,这样很混乱,不利于以后服务 ...
- bootstrap 学习片段
1. 只要单击按钮添加了data-toggle="dropdown"属性, 在单击按钮的时候,默认隐藏的下拉列表就会显示出来 <div class="row&quo ...
- java四大域总结
最近学完了web部分,发现有些地方总是单个容易理解,可是把所有的放在一起来大杂烩,总是有那么几个知识点容易混淆.其实网上的资料已经够多了,虽然也不乏辛劳的搬运工.可是最终的目的不就是要我们自身理解吗? ...
- 关于antlr包删除问题
在建这个网站,用户登录的时候,涉及查询问题,然后就出现了java.lang.NoSuchMethodError: antlr.collections.AST.getLine()I错误,我一脸蒙逼,后来 ...
- c#泛型方法返回null的问题
c#的泛型方法实现和java实现有点不同,在java中,所有的泛型方法运行时类型必须是引用类型,所以和非泛型一样可以返回null. 但是c#中有点不同,可以同时是值类型和引用类型,而值类型不能赋值nu ...