2017-08-30 18:54:40

writer:pprp

可以跟上一篇博客做个对比,

这种实现不是很好理解,上一篇比较好理解,但是感觉有的地方不够严密

代码如下:

/*
@theme:segmentation/interval T
@writer:pprp
@begin:15:26
@end:16:13
@declare: 使用lazy标记的线段树,HDU 1698
这次写的是带结构体的那种
@date:2017/8/30
*/ #include <iostream>
#include <cstring>
#include <cmath>
#include <cstdio>
#include <cstdlib> using namespace std;
const int maxn = ; struct tree
{
int r, l;
int v; //lazy标记
int mid;//中间的值
} T[maxn<<]; //test:ok
void pushDown(int rt)
{
T[rt<<].v = T[rt<<|].v = T[rt].v;
T[rt].v = -; //-1代表着
} //void build(int rt, int l, int r)
//{
// T[rt].l = l, T[rt].r = r;
// T[rt].v = 1; //因为这个题中认为每个节点的值都是1
// T[rt].mid = (l+r)>>1;
// if(l == r)return ;
// //递归求解对两边进行处理
// build(rt<<1,l,T[rt].mid);
// build(rt<<1|1,T[rt].mid+1,r);
//} void build(int rt,int L,int R)
{
T[rt].l=L,T[rt].r=R;T[rt].mid = (L+R)>>;
T[rt].v=;
if(L==R){return;}
build(rt<<,L,T[rt].mid);
build(rt<<|,T[rt].mid+,R);
} void update(int rt, int L, int R, int z)
{
if(L <= T[rt].l && R >= T[rt].r) //error find
{
T[rt].v = z;
return;
}
else
{
if(T[rt].v != -) //如果不是-1也就是说之前没有被pushdown过,那就pushdown
pushDown(rt);
if(L > T[rt].mid)
update(rt<<|,L,R,z);
else if(R <= T[rt].mid)
update(rt<<,L,R,z);
else //左右都有
{
update(rt<<,L,T[rt].mid,z);
update(rt<<|,T[rt].mid+,R,z);
}
}
} //找到根节点的sum值
int Find(int rt)
{
//判断根节点是否有lazy标记
if(T[rt].v != -)
return T[rt].v * (T[rt].r-T[rt].l+);
else
return Find(rt<<) + Find(rt<<|);
} int main()
{
//freopen("in.txt","r",stdin);
int N,n,m,i,j,k,v,c=;
scanf("%d",&N);
while(N--)
{
scanf("%d %d",&n,&m);
build(,,n);
for(i=;i<=m;++i){
scanf("%d%d%d",&j,&k,&v);
update(,j,k,v);
}
printf("Case %d: The total value of the hook is %d.\n",++c,Find());
}
return ;
}

HDU 1698 just a hook - 带有lazy标记的线段树(用结构体实现)的更多相关文章

  1. HDU1698 just a Hook - 带有lazy标记的线段树

    2017-08-30 16:44:33 writer:pprp 上午刚刚复习了一下不带有lazy标记的线段树, 下午开始学带有lazy标记的线段树 这个是我看大佬代码敲的,但是出了很多问题, 这提醒我 ...

  2. 带有lazy标记的线段树

    #include<bits/stdc++.h> using namespace std; ]; struct st{ int l,r,val,add; }tr[]; void build( ...

  3. HDU 1698 Just a Hook(线段树 区间替换)

    Just a Hook [题目链接]Just a Hook [题目类型]线段树 区间替换 &题解: 线段树 区间替换 和区间求和 模板题 只不过不需要查询 题里只问了全部区间的和,所以seg[ ...

  4. HDU 1698 Just a Hook 区间更新 lazy标记

    lazy标记 #include <iostream> #include <cstdio> #include <cstring> #include <sstre ...

  5. 题解报告:hdu 1698 Just a Hook(线段树区间修改+lazy懒标记的运用)

    Problem Description In the game of DotA, Pudge’s meat hook is actually the most horrible thing for m ...

  6. HDU 1698 Just a Hook (线段树 成段更新 lazy-tag思想)

    题目链接 题意: n个挂钩,q次询问,每个挂钩可能的值为1 2 3,  初始值为1,每次询问 把从x到Y区间内的值改变为z.求最后的总的值. 分析:用val记录这一个区间的值,val == -1表示这 ...

  7. hdu 1698 Just a Hook 【线段树+lazy】

    题目 写了一天的线段树,这道题主要说明一下sum是赋值的,不是累加的,并且在push_down的时候lazy也是赋值的.因可能对懒标记的理解还不是很透彻吧. #include <iostream ...

  8. HDU 1698——Just a Hook——————【线段树区间替换、区间求和】

    Just a Hook Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit  ...

  9. HDU 1698 Just a Hook(线段树区间替换)

    题目地址:pid=1698">HDU 1698 区间替换裸题.相同利用lazy延迟标记数组,这里仅仅是当lazy下放的时候把以下的lazy也所有改成lazy就好了. 代码例如以下: # ...

随机推荐

  1. 前端开发 - JQuery&Bootstrap - 总结

    一.JavaScript和Jquery的区别 1.javascript的缺点: 1.书写繁琐,代码量大 2.代码复杂 3.动画效果,很难实现.使用定时器 各种操作和处理 2.定义: 1.Javascr ...

  2. HBase简单API

    一.使用IDEA的maven工程,工程结构如下: 二.maven的依赖pom.xml文件 <?xml version="1.0" encoding="UTF-8&q ...

  3. new Option() 创建一个option标签

    //add() 方法用于向 <select> 添加一个 <option> 元素. //new Option() 创建一个option标签 school.add(new Opti ...

  4. JVM类加载器工作流程

    类加载器 classloader:谈到类加载,不得不提的就是负责此项工作的类加载器classloader,classloader的职责是将Java源文件编译后的字节码文件加载到内存中去执行. 类加载至 ...

  5. Jenkins节点配置页面,启动方法没有"Launch agent via Java Web Start"解决方法?

    Jenkins的配置从节点中默认没有Launch agent via JavaWeb Start,解决办法: 步骤: 1:打开"系统管理"——"Configure Glo ...

  6. 格式化字符串函数sprintf

    sprintf.snprintf相关函数的主要功能是把格式化的数据写入某个字符串.如最常见的应用是将整数或浮点数转换为字符串. 1.sprintf 将格式化的数据写入字符串,并自动在末尾加上一个空字符 ...

  7. Delphi APP 開發入門(八)SQLite資料庫

    Delphi APP 開發入門(八)SQLite資料庫 分享: Share on facebookShare on twitterShare on google_plusone_share   閲讀次 ...

  8. 函数对象[条款18]---《C++必知必会》

    有时需要一些行为类似于函数指针的东西,但函数指针显得笨拙.危险而且过时(让我们承认这一点).通常最佳方式是使用函数对象(function object)取代函数指针. 与智能指针一样,函数对象也是一个 ...

  9. React:快速上手(7)——使用中间件实现异步操作

    React:快速上手(7)——使用中间件实现异步操作 本文参考链接:Stack Overflow redux-thunk 我们使用store.dispath进行派发时,只能传递一个普通对象进去,如下: ...

  10. python xpath 中的全部用法

    不好意思 ,太仓促只能给你们个url 链接:https://blog.csdn.net/hhtnan/article/details/77509549