题目链接

BZOJ1513

题解

真正地理解了一波线段树标记永久化的姿势

每个节点维护两个值\(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 【二维线段树】的更多相关文章

  1. 【BZOJ1513】[POI2006]Tet-Tetris 3D 二维线段树

    [BZOJ1513][POI2006]Tet-Tetris 3D Description Task: Tetris 3D "Tetris" 游戏的作者决定做一个新的游戏, 一个三维 ...

  2. bzoj 1513 POI2006 Tet-Tetris 3D 二维线段树+标记永久化

    1511: [POI2006]OKR-Periods of Words Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 351  Solved: 220[S ...

  3. 洛谷.3437.[POI2006]TET-Tetris 3D(二维线段树)

    题目链接 下落一个d*s的方块,则要在这个平面区域找一个最高的h' 更新整个平面区域的值为h+h' 对于本题,维护最大高度h和all 对于平面的x轴维护一棵线段树t1,每个t1的节点维护对应y轴的两棵 ...

  4. 洛谷P3437 [POI2006]TET-Tetris 3D(二维线段树 标记永久化)

    题意 题目链接 Sol 二维线段树空间复杂度是多少啊qwqqq 为啥这题全网空间都是\(n^2\)还有人硬要说是\(nlog^2n\)呀.. 对于这题来说,因为有修改操作,我们需要在外层线段树上也打标 ...

  5. UVA 11297 线段树套线段树(二维线段树)

    题目大意: 就是在二维的空间内进行单个的修改,或者进行整块矩形区域的最大最小值查询 二维线段树树,要注意的是第一维上不是叶子形成的第二维线段树和叶子形成的第二维线段树要  不同的处理方式,非叶子形成的 ...

  6. POJ2155 Matrix二维线段树经典题

    题目链接 二维树状数组 #include<iostream> #include<math.h> #include<algorithm> #include<st ...

  7. HDU 1823 Luck and Love(二维线段树)

    之前只知道这个东西的大概概念,没具体去写,最近呵呵,今补上. 二维线段树 -- 点更段查 #include <cstdio> #include <cstring> #inclu ...

  8. poj 2155:Matrix(二维线段树,矩阵取反,好题)

    Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 17880   Accepted: 6709 Descripti ...

  9. poj 1195:Mobile phones(二维线段树,矩阵求和)

    Mobile phones Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 14391   Accepted: 6685 De ...

  10. POJ 2155 Matrix (二维线段树)

    Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 17226   Accepted: 6461 Descripti ...

随机推荐

  1. mysql-介绍

    1.mysql几个重要的文件 每个数据库新建后,会产生数据库文件夹,在该文件夹下每张表均对应以下三个文件: xx.frm  存放表结构 xx.MYD    存放表数据 xx.MYI 存放表索引 mys ...

  2. 【php】php 生僻知识点认知

    资料引用来源:http://www.runoob.com/php/php-tutorial.html ​ 表单提交中, 变量名中的点和空格被转换成下划线.例如 <input name=" ...

  3. python应用:主题分类(gensim lda)

    安装第三方包:gensim 首先,执行去停词操作(去除与主题无关的词) #-*-coding:utf8-*- import jieba def stopwordslist(filepath): sto ...

  4. Logistic Regression学习笔记

    1.李航<统计学习方法>: 2.https://blog.csdn.net/laobai1015/article/details/78113214 3.http://www.cnblogs ...

  5. 【MySql】mysql 慢日志查询工具之mysqldumpslow

      当使用--log-slow-queries[=file_name]选项启动时,mysqld写一个包含所有执行时间超过long_query_time秒的SQL语句的日志文件.获得初使表锁定的时间不算 ...

  6. uber司机已经激活了,就是还没有上传头

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  7. Mac OS下搭建Hadoop + Spark集群

    首先注意版本兼容问题!!!本文采用的是Scala 2.11.8 + Hadoop 2.7.5 + Spark 2.2.0 请在下载Spark时务必看清对应的Scala和Hadoop版本! 一.配置JD ...

  8. Java - 问题集 - linux下,jar: command not found

    linux下的找不到jar命令解决方法如下: 1. 确认jdk是否已安装 2. 检查jdk环境变量是否已设置,并且确认该设置已生效 3. 1,2两步均正常时,建立jar的软链接 # cd /usr/b ...

  9. java线程池技术

    1.线程池的实现原理?简介: 多线程技术主要解决处理器单元内多个线程执行的问题,它可以显著减少处理器单元的闲置时间,增加处理器单元的吞吐能力.假设一个服务器完成一项任务所需时间为:T1 创建线程时间, ...

  10. Linux下创建pycharm的快捷方式

    第一步:创建桌面快捷方式文件Pycharm.desktop,并打开 sudo gedit /usr/share/applications/Pycharm.desktop 第二步:在打开的文件Pycha ...