二维线段树区间更新啊

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

然而起码对于这题是可以的...对于外层线段树,每个节点放两个内层线段树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. JS基础:正则表达式

    简介 正则表达式 (regular expression) 描述了一种字符串匹配的模式,可以用来检查一个字符串是否含有某种子串.将匹配的子串做替换或者从某个字符串中取出符合某个条件的子串等.在 JS ...

  2. 如何将一个本来需要发几十条sql语句的需求优化成两条(非sql语句优化,而是解决方法)

    首先声明,本人所有博客均为原创,谢绝转载! 今天接到一个需求,如下 这里解释一下,为什么是几十条,因为这里面每个公式的每个条件都是一个单独的数据如净利润就是一条sql语句,而且分散在不同的表,如果此方 ...

  3. 【ZJOI2017 Round1练习】D7T1 graph(提答)

    题意: n<=1000 m<=10000 思路:

  4. Being a Good Boy in Spring Festival 博弈论 Nim博弈

    易游戏雷火盘古校园招聘开始! kiki's game Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 40000/10000 K (Ja ...

  5. 用 字蛛 取出需要的字符应用字体 @font-face

    一.安装font-spider npm install font-spider -g 二.目录结构 font-spider font FZZZHONGHJW.ttf font.html 三.font. ...

  6. scp、paramiko、rsync复制文件的区别

    1.paramiko只能复制文件,而不能复制目录,复制时,已经存在的会被覆盖;要想复制目录,只能把目录里的文件一个一个复制过去 2.scp可以复制文件.目录,复制时,已经存在的会被覆盖:可以模糊匹配: ...

  7. 条款五:对应的new和delete要采用相同的形式

    string *stringarray = new string[100]; ... delete stringarray; 上述程序的运行情况将是不可预测的.至少,stringarray指向的100 ...

  8. HDU 1051 Wooden Sticks 贪心题解

    本题一看就知道是最长不减序列了,一想就以为是使用dp攻克了. 只是那是个错误的思路. 我就动了半天没动出来.然后看了看别人是能够使用dp的,只是那个比較难证明其正确性,而其速度也不快.故此并非非常好的 ...

  9. 连接App.config

    ConfigurationManager.AppSettings["AdminName"]; 连接App.config的字符

  10. 2.eclipse 插件安装烦死人(2)

    安装插件的实际结果是:(烦死人),要不是很多插件找不到,要不就是版本不对,要不就是下载了装上没有效果,要不就是在线安装(速度爆慢),好不容易等到结果了,结果是些错…… 最后我的eclipse 3.5. ...