洛谷 P3437 [POI2006]TET-Tetris 3D
二维线段树区间更新啊
树套树的外层树,如果是线段树的话一般似乎不能打标记?(毕竟标记不好下传)
然而起码对于这题是可以的...对于外层线段树,每个节点放两个内层线段树dat和setv,分别是得到的值和修改操作留下的标记。
然后外层线段树要标记永久化...标记永久化之后,标记的定义不一样了。
这道题里用dat[i]表示i节点表示的整段区间都达到的值,setv[i]表示i节点表示的区间的最大值。
(这两个的名字似乎反了?)
这样进行修改操作的时候,更新所有经过的节点的setv(因为只要经过该点,那么该点表示的区间和目标区间一定有相交部分),更新被目标区间完全包含的区间所在节点的dat(自然整段都达到那个值了)
进行查询操作的时候,"所有经过节点的dat"和"所有被目标区间完全包含的区间所在节点的setv"的最大值就是答案。
二维都一样,只不过外层线段树的查询是对于内层线段树的给定区间查询/修改
标记不下传
(一眼看起来似乎不是很对?有些信息被遗漏了?然而的确是对的23333)
(似乎修改和查询完全是对称的...)
错误记录:71行少了分号后的两个语句导致WA一片
#include<cstdio>
#include<algorithm>
#include<cstring>
#define lc (num<<1)
#define rc (num<<1|1)
#define mid ((l+r)>>1)
using namespace std;
int n,m;
namespace XXX
{
int L,R,x;
struct Y
{
int dat[],setv[];
//dat表示整段区间都达到的值,setv表示区间最大值
void update(int l,int r,int num)
{
setv[num]=max(setv[num],x);
if(L<=l&&r<=R)
{
dat[num]=max(dat[num],x);
return;
}
if(L<=mid) update(l,mid,lc);
if(mid<R) update(mid+,r,rc);
}
int query(int l,int r,int num)
{
if(L<=l&&r<=R) return setv[num];
int ans=dat[num];
if(L<=mid) ans=max(ans,query(l,mid,lc));
if(mid<R) ans=max(ans,query(mid+,r,rc));
return ans;
}
};
}
int L,R,x;
XXX::Y dat[],setv[];
void update(int l,int r,int num)
{
XXX::x=x;
setv[num].update(,m,);
if(L<=l&&r<=R)
{
XXX::x=x;
dat[num].update(,m,);
return;
}
if(L<=mid) update(l,mid,lc);
if(mid<R) update(mid+,r,rc);
}
int query(int l,int r,int num)
{
if(L<=l&&r<=R) return setv[num].query(,m,);
int ans=dat[num].query(,m,);
if(L<=mid) ans=max(ans,query(l,mid,lc));
if(mid<R) ans=max(ans,query(mid+,r,rc));
return ans;
}
int main()
{
int Q,d,s,w,xx,yy;
scanf("%d%d%d",&n,&m,&Q);
while(Q--)
{
scanf("%d%d%d%d%d",&d,&s,&w,&xx,&yy);xx++;yy++;
L=xx;R=xx+d-;XXX::L=yy;XXX::R=yy+s-;
x=query(,n,)+w;//printf("%d\n",x);
update(,n,);
}
L=;R=n;XXX::L=;XXX::R=m;
printf("%d",query(,n,));
return ;
}
洛谷 P3437 [POI2006]TET-Tetris 3D的更多相关文章
- 洛谷 P3437 [POI2006]TET-Tetris 3D 解题报告
P3437 [POI2006]TET-Tetris 3D 题目描述 The authors of the game "Tetris" have decided to make a ...
- 洛谷P3437 [POI2006]TET-Tetris 3D(二维线段树 标记永久化)
题意 题目链接 Sol 二维线段树空间复杂度是多少啊qwqqq 为啥这题全网空间都是\(n^2\)还有人硬要说是\(nlog^2n\)呀.. 对于这题来说,因为有修改操作,我们需要在外层线段树上也打标 ...
- [洛谷P3444] [POI2006]ORK-Ploughing
洛谷题目链接[POI2006]ORK-Ploughing 题目描述 Byteasar, the farmer, wants to plough his rectangular field. He ca ...
- 洛谷P3434 [POI2006]KRA-The Disks(线段树)
洛谷题目传送门 \(O(n)\)的正解算法对我这个小蒟蒻真的还有点思维难度.洛谷题解里都讲得很好. 考试的时候一看到300000就直接去想各种带log的做法了,反正不怕T...... 我永远只会有最直 ...
- 洛谷P3435 [POI2006]OKR-Period of Words [KMP]
洛谷传送门,BZOJ传送门 OKR-Period of Words Description 一个串是有限个小写字符的序列,特别的,一个空序列也可以是一个串. 一个串P是串A的前缀, 当且仅当存在串B, ...
- 洛谷P3434 [POI2006]KRA-The Disks [模拟]
题目传送门 KRA 题目描述 For his birthday present little Johnny has received from his parents a new plaything ...
- 【题解】洛谷P3435 [POI2006] OKR-Periods of Words(KMP)
洛谷P3435:https://www.luogu.org/problemnew/show/P3435 思路 来自Kamijoulndex大佬的解释 先把题面转成人话: 对于给定串的每个前缀i,求最长 ...
- 洛谷.3437.[POI2006]TET-Tetris 3D(二维线段树)
题目链接 下落一个d*s的方块,则要在这个平面区域找一个最高的h' 更新整个平面区域的值为h+h' 对于本题,维护最大高度h和all 对于平面的x轴维护一棵线段树t1,每个t1的节点维护对应y轴的两棵 ...
- 洛谷P3434 [POI2006]KRA-The Disks
P3434 [POI2006]KRA-The Disks 题目描述 For his birthday present little Johnny has received from his paren ...
随机推荐
- DEA中MAVEN项目有多个子目录,如何加载构建
ddts这个项目有三个子目录,每个子目录下面也都有一个 pom.xml 此时需要 右键子目录的 pom.xml,选择Add as Maven Project,在上图中cli.core两个目 ...
- 一练Splay之维修数列第一次
平衡树并不是之前没写过,觉得有必要把平衡树变成考场上能敲的东西,也就是说,考一道诸如“维修数列”这样的送分题,要能拿满分. 维修数列.给定一个数列支持以下操作: 输入的第1 行包含两个数N 和M(M ...
- [转] 结构体file_operations
原文地址: http://www.cnblogs.com/sunyubo/archive/2010/12/22/2282079.html 结构体file_operations在头文件 linux/fs ...
- Ubuntu 12.04 之 虚拟主机的配置
Ubuntu 12.04 之 虚拟主机的配置 (1)打开etc/hosts文件 增加: 127.0.0.1 study.ubuntu.com 127.0.0.1 hello.ubuntu.com 12 ...
- POJ 1769_Minimizing maximizer
题意: 一系列m个1~n区间,每个区间固定对某个子区间进行排序,顺序选择若干区间,使最终覆盖所有区间. 分析: computes the length of the shortest subseque ...
- operamasks-omGrid的使用
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="personTab.aspx ...
- 用Visual Studio 2010 打开Visual Studio 2013 (C#专用)
1.更改.sln 1)将Microsoft Visual Studio Solution File, Format Version 12.00 改成11.00 2)将 # Visual Studi ...
- windows 7中添加新硬件的两种方法(本地回环网卡)
最近在windows7上使用VMwareWorkstation7玩一些实验,遇到需要配置不同网络的问题. 因为在windows2003server上习惯使用要本地回环网卡了,那就想着在Windows7 ...
- 【bzoj1787】&【bzoj1832】[Ahoi2008]Meet 紧急集合 & 聚会
bzoj1787就是bzoj1832 bzoj1832 空间和时间少了一些... 求三个结点到一个结点距离之和最小的结点以及距离和 求出两两lca,其中有两个相同,答案则为另一个 感觉就是一大暴力.. ...
- 【hdu3966】Aragorn's Story
题意:给一棵树,并给定各个点权的值,然后有3种操作:I C1 C2 K: 把C1与C2的路径上的所有点权值加上KD C1 C2 K:把C1与C2的路径上的所有点权值减去KQ C:查询节点编号为C的权值 ...