USACO08FEB Hotel
线段树维护区间
- 线段树结构体
struct zzz{
int l,r,mi;
//l为以左端点的为起点的最长子串
//r为以右端点为终点的最长子串
//mi是区间内部的最长子串
}tree[50010<<2];
- 合并
合并的时候要考虑左右区间互拼的情况
inline void up(int l,int r,int p){
if(tree[ls].l==mid-l+1)
tree[p].l=tree[ls].l+tree[rs].l;
else tree[p].l=tree[ls].l;
if(tree[rs].r==r-mid)
tree[p].r=tree[rs].r+tree[ls].r;
else tree[p].r=tree[rs].r;
tree[p].mi=max(max(tree[ls].mi,tree[rs].mi),tree[ls].r+tree[rs].l);
}
- 询问
因为要查找最左的房间,所以尽量向左找
int query(int l,int r,int p,int k){
down(l,r,p);
if(l==r) return l;
if(tree[ls].mi>=k) return query(l,mid,ls,k);
if(tree[ls].r+tree[rs].l>=k) return mid-tree[ls].r+1;
return query(mid+1,r,rs,k);
}
最核心的就是这几个函数了,别的函数基本没有变化,直接看总代码就好
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define LL long long
#define ls p<<1
#define rs p<<1|1
#define mid ((l+r)>>1)
using namespace std;
int read(){
int k=0,f=1; char c=getchar();
for(;c<'0'||c>'9';c=getchar())
if(c=='-') f=-1;
for(;c>='0'&&c<='9';c=getchar())
k=k*10+c-48;
return k*f;
}
struct zzz{
int l,r,mi;
}tree[50010<<2]; int tag[50010<<2];
inline void up(int l,int r,int p){
if(tree[ls].l==mid-l+1)
tree[p].l=tree[ls].l+tree[rs].l;
else tree[p].l=tree[ls].l;
if(tree[rs].r==r-mid)
tree[p].r=tree[rs].r+tree[ls].r;
else tree[p].r=tree[rs].r;
tree[p].mi=max(max(tree[ls].mi,tree[rs].mi),tree[ls].r+tree[rs].l);
}
void build(int l,int r,int p){
if(l==r){
tree[p].l=tree[p].r=tree[p].mi=1;
return ;
}
build(l,mid,ls); build(mid+1,r,rs);
up(l,r,p);
}
inline void down(int l,int r,int p){
if(tag[p]==-1) return ;
tree[ls].l=tree[ls].mi=tree[ls].r=(mid-l+1)*tag[p];
tree[rs].l=tree[rs].mi=tree[rs].r=(r-mid)*tag[p];
tag[ls]=tag[rs]=tag[p];
tag[p]=-1;
}
int query(int l,int r,int p,int k){
down(l,r,p);
if(l==r) return l;
if(tree[ls].mi>=k) return query(l,mid,ls,k);
if(tree[ls].r+tree[rs].l>=k) return mid-tree[ls].r+1;
return query(mid+1,r,rs,k);
}
void update(int l,int r,int p,int nl,int nr,int k){
if(l>=nl&&r<=nr){
tree[p].l=tree[p].r=tree[p].mi=k*(r-l+1);
tag[p]=k; return ;
}
down(l,r,p);
if(nl<=mid) update(l,mid,ls,nl,nr,k);
if(nr>mid) update(mid+1,r,rs,nl,nr,k);
up(l,r,p);
}
int main(){
int n=read(),m=read();
memset(tag,-1,sizeof(tag));
build(1,n,1);
for(int i=1;i<=m;i++){
int k=read();
if(k==1){
int x=read();
if(tree[1].mi<x){
printf("0\n"); continue;
}
int pos=query(1,n,1,x);
printf("%d\n",pos);
update(1,n,1,pos,pos+x-1,0);
}
else{
int x=read(),y=read();
update(1,n,1,x,x+y-1,1);
}
}
return 0;
}
USACO08FEB Hotel的更多相关文章
- [USACO08FEB]Hotel 题解
正确的题解 首先我们都知道这题要用线段树做.考虑维护靠左边的answer,靠右边的answer,和整个区间的answer,那么就珂以维护这道题目了. 这里比较复杂的有下传操作和上传操作. 上传 voi ...
- 洛谷P2894 [USACO08FEB]酒店Hotel
P2894 [USACO08FEB]酒店Hotel https://www.luogu.org/problem/show?pid=2894 题目描述 The cows are journeying n ...
- 线段树||BZOJ1593: [Usaco2008 Feb]Hotel 旅馆||Luogu P2894 [USACO08FEB]酒店Hotel
题面:P2894 [USACO08FEB]酒店Hotel 题解:和基础的线段树操作差别不是很大,就是在传统的线段树基础上多维护一段区间最长的合法前驱(h_),最长合法后驱(t_),一段中最长的合法区间 ...
- P2894 [USACO08FEB]酒店Hotel
P2894 [USACO08FEB]酒店Hotel 简单的线段树维护区间信息. 维护三个值,一个是从左端点能拓展的长度,一个是从右端点能脱产的的长度.另一个是整个区间内的最大连续零一长度. 记录这三个 ...
- 洛谷 P2894 [USACO08FEB]酒店Hotel 解题报告
P2894 [USACO08FEB]酒店Hotel 题目描述 The cows are journeying north to Thunder Bay in Canada to gain cultur ...
- 线段树【洛谷P2894】 [USACO08FEB]酒店Hotel
P2894 [USACO08FEB]酒店Hotel 参考样例,第一行输入n,m ,n代表有n个房间,编号为1---n,开始都为空房,m表示以下有m行操作,以下 每行先输入一个数 i ,表示一种操作: ...
- 浅谈线段树 (例题:[USACO08FEB]酒店Hotel)By cellur925
今天我们说说线段树. 我个人还是非常欣赏这种数据结构的.(逃)因为它足够优美,有递归结构,有左子树和右子树,还有二分的思想. emm这个文章打算自用,就不写那些基本的操作了... 1° 简单的懒标记( ...
- [USACO08FEB]酒店Hotel 线段树
[USACO08FEB]酒店Hotel 线段树 题面 其实就是区间多维护一个lmax,rmax(表示从左开始有连续lmax个空房,一直有连续rmax个空房到最右边),合并时讨论一下即可. void p ...
- 洛谷P2894 [USACO08FEB]酒店Hotel [线段树]
题目传送门 酒店 题目描述 The cows are journeying north to Thunder Bay in Canada to gain cultural enrichment and ...
随机推荐
- ffmpeg h264转h265
ffmpeg -i d:\soft\720p.mp4 -c:v libx265 -b:v 5000k d:\soft\myvideo.mp4 这里码率是5000k,编码是h265 h265的解码貌似用 ...
- codeforces1081G Mergesort Strikes Back【期望dp+脑洞】
首先看这样做的特点,就是分到最后小块里的点合并上去的时候相对顺序不变,所以先加上块内逆序对的期望 合并的时候一定是一边卡住一个大值,另一边跳指针,所以把一个值向右直到有大于它的值位置的一段区间看作一段 ...
- Tyvj P1520 树的直径
P1520 树的直径 http://www.tyvj.cn/p/1520 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 树的直径,即这棵树中距离最远的两个结 ...
- uoj#388. 【UNR #3】配对树(线段树合并)
传送门 先考虑一个贪心,对于一条边来说,如果当前这个序列中在它的子树中的元素个数为奇数个,那么这条边就会被一组匹配经过,否则就不会 考虑反证法,如果在这条边两边的元素个数都是偶数,那么至少有两组匹配经 ...
- SpringBoot2.0 基础案例(06):引入JdbcTemplate,和多数据源配置
一.JdbcTemplate对象 1.JdbcTemplate简介 在Spring Boot2.0框架下配置数据源和通过JdbcTemplate访问数据库的案例. SpringBoot对数据库的操作在 ...
- How to generate a CSR in Microsoft IIS 7
How to generate a CSR in Microsoft IIS 7 To help you generate your CSR for Microsoft IIS 7 we've pre ...
- IntelliJ IDEA 安装golang 插件
作者的机器为mac OS 用户首先需要在自己的个人机器上安装好 golang 的环境,详细可以参考 hyperledger fabric 1.0.5 分布式部署 (一)安装 golang 的部分. ...
- Luogu P1438无聊的序列【线段树/差分】By cellur925
题目传送门 题目大意:维护一个序列,维护区间加等差数列,单点查询的操作. 首先我们肯定是要用线段树来维护了,按照一般的思维局限,我选择了维护序列中的值,但是区间修改的时候由于公差的存在,所以区间修改有 ...
- Java工程打包成jar可执行文件
将一个工程中的类打包成jar文件,步骤参考如下: 1.选择file -> project structure 2. 选择Arifacts->JAR->form modules wit ...
- Jmeter 的 vars 和 props 用法
meter 的 JSR223 控件是 代替 BeanShell 的新一代脚本控件,支持多种脚本语言,尤其是其中的 Groovy,更是重点推荐使用的脚本语言,本文研究其中的 vars 和 props 两 ...