BZOJ1513 [POI2006]Tet-Tetris 3D 【二维线段树】
题目链接
题解
真正地理解了一波线段树标记永久化的姿势
每个节点维护两个值\(v\)和\(tag\)
\(v\)代表儿子中的最值
\(tag\)代表未下传的最值
显然节点的区间大于等于\(v\)的实际区间
而\(tag\)的区间包含节点的区间
我们在修改的时候,沿路\(v\)都要修改,底层\(tag\)修改
我们在查询的时候,沿路\(tag\)都要查询,底层\(v\)查询
\(upd:\)理解层面上看,和普通线段树是一样的嘛,,,,
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<map>
#define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt)
#define REP(i,n) for (int i = 1; i <= (n); i++)
#define mp(a,b) make_pair<int,int>(a,b)
#define cls(s) memset(s,0,sizeof(s))
#define cp pair<int,int>
#define LL long long int
#define ls (u << 1)
#define rs (u << 1 | 1)
using namespace std;
const int maxn = 4005,maxm = 5000005,INF = 1000000000;
inline int read(){
int out = 0,flag = 1; char c = getchar();
while (c < 48 || c > 57){if (c == '-') flag = -1; c = getchar();}
while (c >= 48 && c <= 57){out = (out << 3) + (out << 1) + c - 48; c = getchar();}
return out * flag;
}
int n,D,S;
struct segx{
int mx[maxm],lc[maxm],rc[maxm],tag[maxm],cnt;
void modify(int& u,int l,int r,int L,int R,int v){
if (!u) u = ++cnt; mx[u] = max(mx[u],v);
if (l >= L && r <= R){tag[u] = max(tag[u],v); return;}
int mid = l + r >> 1;
if (mid >= L) modify(lc[u],l,mid,L,R,v);
if (mid < R) modify(rc[u],mid + 1,r,L,R,v);
}
int query(int u,int l,int r,int L,int R){
if (!u) return 0;
if (l >= L && r <= R) return mx[u];
int mid = l + r >> 1,ans = tag[u];
if (mid >= R) return max(ans,query(lc[u],l,mid,L,R));
if (mid < L) return max(ans,query(rc[u],mid + 1,r,L,R));
return max(ans,max(query(lc[u],l,mid,L,R),query(rc[u],mid + 1,r,L,R)));
}
}Seg;
struct segy{
int rt[maxn],tag[maxn];
void modify(int u,int l,int r,int L,int R,int ll,int rr,int v){
Seg.modify(rt[u],1,S,ll,rr,v);
if (l >= L && r <= R){Seg.modify(tag[u],1,S,ll,rr,v); return;}
int mid = l + r >> 1;
if (mid >= L) modify(ls,l,mid,L,R,ll,rr,v);
if (mid < R) modify(rs,mid + 1,r,L,R,ll,rr,v);
}
int query(int u,int l,int r,int L,int R,int ll,int rr){
if (l >= L && r <= R) return Seg.query(rt[u],1,S,ll,rr);
int mid = l + r >> 1,ans = Seg.query(tag[u],1,S,ll,rr);
if (mid >= L) ans = max(ans,query(ls,l,mid,L,R,ll,rr));
if (mid < R) ans = max(ans,query(rs,mid + 1,r,L,R,ll,rr));
return ans;
}
}T;
int main(){
D = read(); S = read(); n = read();
int d,s,h,x0,y0,x,y,xx,yy;
while (n--){
d = read(); s = read(); h = read(); x0 = read(); y0 = read();
x = x0 + 1; y = y0 + 1; xx = x0 + d; yy = y0 + s;
h += T.query(1,1,D,x,xx,y,yy);
T.modify(1,1,D,x,xx,y,yy,h);
}
printf("%d\n",T.query(1,1,D,1,D,1,S));
return 0;
}
BZOJ1513 [POI2006]Tet-Tetris 3D 【二维线段树】的更多相关文章
- 【BZOJ1513】[POI2006]Tet-Tetris 3D 二维线段树
[BZOJ1513][POI2006]Tet-Tetris 3D Description Task: Tetris 3D "Tetris" 游戏的作者决定做一个新的游戏, 一个三维 ...
- bzoj 1513 POI2006 Tet-Tetris 3D 二维线段树+标记永久化
1511: [POI2006]OKR-Periods of Words Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 351 Solved: 220[S ...
- 洛谷.3437.[POI2006]TET-Tetris 3D(二维线段树)
题目链接 下落一个d*s的方块,则要在这个平面区域找一个最高的h' 更新整个平面区域的值为h+h' 对于本题,维护最大高度h和all 对于平面的x轴维护一棵线段树t1,每个t1的节点维护对应y轴的两棵 ...
- 洛谷P3437 [POI2006]TET-Tetris 3D(二维线段树 标记永久化)
题意 题目链接 Sol 二维线段树空间复杂度是多少啊qwqqq 为啥这题全网空间都是\(n^2\)还有人硬要说是\(nlog^2n\)呀.. 对于这题来说,因为有修改操作,我们需要在外层线段树上也打标 ...
- UVA 11297 线段树套线段树(二维线段树)
题目大意: 就是在二维的空间内进行单个的修改,或者进行整块矩形区域的最大最小值查询 二维线段树树,要注意的是第一维上不是叶子形成的第二维线段树和叶子形成的第二维线段树要 不同的处理方式,非叶子形成的 ...
- POJ2155 Matrix二维线段树经典题
题目链接 二维树状数组 #include<iostream> #include<math.h> #include<algorithm> #include<st ...
- HDU 1823 Luck and Love(二维线段树)
之前只知道这个东西的大概概念,没具体去写,最近呵呵,今补上. 二维线段树 -- 点更段查 #include <cstdio> #include <cstring> #inclu ...
- poj 2155:Matrix(二维线段树,矩阵取反,好题)
Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 17880 Accepted: 6709 Descripti ...
- poj 1195:Mobile phones(二维线段树,矩阵求和)
Mobile phones Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 14391 Accepted: 6685 De ...
- POJ 2155 Matrix (二维线段树)
Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 17226 Accepted: 6461 Descripti ...
随机推荐
- php 无限参数方法
在很多项目开发中经常会用到共用方法但是参数不固定,每个参数都创建一遍阅读性不好,后期维护也麻烦,PHP有获取传入参数的方法,记录参考一下.这里有两个方法 <?php 方法一: #不指定参数个数方 ...
- u-boot-2016.01移植(一)
1.了解uboot: 阅读uboot源码顶层目录下的README.TXT可以提取如下信息: made to support booting of Linux images. //引导内核程 ...
- poj 2393 奶牛场生产成本问题 贪心算法
题意:有一个奶牛场,第i周的生产成本为c,需要数量为 y,每周的存储成本为s.问怎么安排使得成本最低? 思路: 成本最低是吧?求出每周的最低成本*该周需要的数量就是成本最低 每周的成本有两个:自己本周 ...
- HASH算法小结
一.简述 HASH算法的本质是特征提取——将某种不太好表示的特征,通过某种压缩的方式映射成一个值.这样,就可以优雅解决一部分难以解决的特征统计问题. 同时考虑到hash算法的本质是个概率算法,因此并不 ...
- jenkins 构建部署时tomcat7 内存溢出解决方案
在使用jenkins构建部署时一直出现tomcat7内存溢出 WARNING: Unexpected node monitoring termination: Clock Difference jav ...
- 【WPF】 布局篇
[WPF] 布局篇 一. 几个常用且至关重要的属性 1. Width,Height : 设置窗体,控件宽高. 这里注意,WPF是自适应的, 所以把这2个属性设置 Auto, 则控件宽高会自动改变. 2 ...
- Hackerrank - [Algo] Matrix Rotation
https://www.hackerrank.com/challenges/matrix-rotation-algo 又是一道耗了两小时以上的题,做完了才想起来,这不就是几年前在POJ上做过的一个同类 ...
- Android Google Maps 开始
由于工作需要,最近对Android的各大地图进行了试用. 其中有Google地图,百度地图,高德地图,还有开源的OSM. 在使用Google地图的时候,官网流程写的非常清楚,但是其中也遇到一些问题.这 ...
- 「Haskell 学习」二 类型和函数(上)
随着学习的深入,笔记会补充和修订.当然,这个补充修订也许会鸽,但我一定会坚持写完. 这个笔记假定你至少学过C/C++及Python,或与这两种语言类型相同的语言. 类型系统概述 “Haskell’s ...
- 【Selenium-Python】Selenium-Firefox 环境配置 win64
Python 已安装完毕 Selenium 安装: Windows > cmd pip install selenium 注:未加selenium版本号时默认安装最新版本. 查询当前Seleni ...