二维线段树区间更新啊

树套树的外层树,如果是线段树的话一般似乎不能打标记?(毕竟标记不好下传)

然而起码对于这题是可以的...对于外层线段树,每个节点放两个内层线段树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的更多相关文章

  1. 洛谷 P3437 [POI2006]TET-Tetris 3D 解题报告

    P3437 [POI2006]TET-Tetris 3D 题目描述 The authors of the game "Tetris" have decided to make a ...

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

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

  3. [洛谷P3444] [POI2006]ORK-Ploughing

    洛谷题目链接[POI2006]ORK-Ploughing 题目描述 Byteasar, the farmer, wants to plough his rectangular field. He ca ...

  4. 洛谷P3434 [POI2006]KRA-The Disks(线段树)

    洛谷题目传送门 \(O(n)\)的正解算法对我这个小蒟蒻真的还有点思维难度.洛谷题解里都讲得很好. 考试的时候一看到300000就直接去想各种带log的做法了,反正不怕T...... 我永远只会有最直 ...

  5. 洛谷P3435 [POI2006]OKR-Period of Words [KMP]

    洛谷传送门,BZOJ传送门 OKR-Period of Words Description 一个串是有限个小写字符的序列,特别的,一个空序列也可以是一个串. 一个串P是串A的前缀, 当且仅当存在串B, ...

  6. 洛谷P3434 [POI2006]KRA-The Disks [模拟]

    题目传送门 KRA 题目描述 For his birthday present little Johnny has received from his parents a new plaything ...

  7. 【题解】洛谷P3435 [POI2006] OKR-Periods of Words(KMP)

    洛谷P3435:https://www.luogu.org/problemnew/show/P3435 思路 来自Kamijoulndex大佬的解释 先把题面转成人话: 对于给定串的每个前缀i,求最长 ...

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

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

  9. 洛谷P3434 [POI2006]KRA-The Disks

    P3434 [POI2006]KRA-The Disks 题目描述 For his birthday present little Johnny has received from his paren ...

随机推荐

  1. msp430入门编程10

    msp430中C语言操作端口I/O10 msp430中C语言的模块化头文件及实现11 msp430中C语言的模块化头文件及库文件12 msp430入门学习 msp430入门编程

  2. School Marks-CodeForces

    B. School Marks time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...

  3. windows下编译jpeg

    项目为了脱离OpenCV,直接采用libjpeg,记录在windows下jpeg安装. 项目地址http://www.ijg.org/ 下载解压缩jpeg-9a 看了看OpenCV中对libjpeg的 ...

  4. 冲刺Offer - 二叉树的深度

    https://www.nowcoder.net/practice/435fb86331474282a3499955f0a41e8b?tpId=13&tqId=11191&tPage= ...

  5. 操作系统——IO管理

    一.IO系统结构 在计算机系统中.cpu要和很多外设进行交互.比方鼠标,键盘,网卡等等. 1.IO是怎样协调工作的那? (1)对于设备来说,其有两部分组成,一部分是机械部分,还有一部分是电子控制部分. ...

  6. hdu oj 3127 WHUgirls(2009 Asia Wuhan Regional Contest Online)

    WHUgirls Time Limit: 3000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) Total ...

  7. Mahout贝叶斯算法拓展篇3---分类无标签数据

    代码測试环境:Hadoop2.4+Mahout1.0 前面博客:mahout贝叶斯算法开发思路(拓展篇)1和mahout贝叶斯算法开发思路(拓展篇)2 分析了Mahout中贝叶斯算法针对数值型数据的处 ...

  8. Vijos P1023Victoria的舞会3【贪心+DFS求强联通分量】

    链接:Click Me! P1023Victoria的舞会3 Accepted 标签:Victoria的舞会[显示标签] 描写叙述 Victoria是一位颇有成就的艺术家,他因油画作品<我爱北京 ...

  9. SP2-0734: 未知的命令开头 &quot;imp scott/...&quot; - 忽略了剩余的行。

    Oracle数据导入报错:SP2-0734: 未知的命令开头 "imp scott/..." - 忽略了剩余的行. 原因:进入sqlplus里是不能运行imp的(sqlplus不认 ...

  10. Angular Scope解析与应用

    Scope层级结构 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA== ...