Just a Hook (HDU 1698)

题链

每一次都将一个区间整体进行修改,需要用到懒惰标记,懒惰标记的核心在于在查询前才更新,比如将当前点rt标记为col[rt],那么此点的左孩子和右孩子标记必然和其一致(直接替换,如果是累积则另当别论),同时这个区间也能很快求出了

线段树功能:区间更新+区间查询

#include <cstdio>
#include <utility>
#include <queue>
#include <cstring>
#define scan(x) scanf("%d",&x)
#define scan2(x,y) scanf("%d%d",&x,&y)
#define lson rt<<1,l,mid
#define rson rt<<1|1,mid+1,r
#define root 1,1,n
using namespace std;
const int Max=1e5+10;
int sum[Max<<2],col[Max<<2];
void Pushup(int rt)
{
sum[rt]=sum[rt<<1]+sum[rt<<1|1];
}
void Build(int rt,int l,int r)
{
if(l==r)
{
sum[rt]=1;
col[rt]=0;
return;
}
int mid=(l+r)>>1;
Build(lson);
Build(rson);
Pushup(rt);
}
void Pushdown(int rt,int rage)
{
if(col[rt])
{
col[rt<<1]=col[rt<<1|1]=col[rt];
sum[rt<<1]=col[rt]*(rage-(rage>>1));
sum[rt<<1|1]=col[rt]*(rage>>1);
col[rt]=0;
}
}
void Update(int L,int R,int x,int rt,int l,int r)
{
if(L<=l&&r<=R)
{
sum[rt]=x*(r-l+1);
col[rt]=x;
return;
}
Pushdown(rt,(r-l)+1);
int mid=(l+r)>>1;
if(L<=mid) Update(L,R,x,lson);
if(mid<R) Update(L,R,x,rson);
Pushup(rt);
}
int main()
{
int T,ca=1;
for(scan(T);T;T--)
{
memset(sum,0,sizeof(sum));
memset(col,0,sizeof(col));
int l,r,k,n,m;
scan2(n,m);
Build(root);
while(m--)
{
scanf("%d%d%d",&l,&r,&k);
Update(l,r,k,root);
}
printf("Case %d: The total value of the hook is %d.\n",ca++,sum[1]);
}
return 0;
}

重新写了一次,学习了一份新的模板

#include<queue>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define ll long long
#define inf 1000000000
#define mod 1000000007
using namespace std;
int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int n,m;
int a[100005];
int ls[400005],rs[400005];
int M[400005],tag[400005];
void build(int k,int l,int r)
{
int mid=(l+r)>>1;
ls[k]=l;rs[k]=r;tag[k]=0;M[k]=0;
if(l==r){M[k]=1;return;}
build(k<<1,l,mid);
build(k<<1|1,mid+1,r);
M[k]=M[k<<1]+M[k<<1|1];
}
void pushdown(int k)
{
if(!tag[k]||ls[k]==rs[k])return;
tag[k<<1]=tag[k];
tag[k<<1|1]=tag[k];
int rage=(rs[k]-ls[k]+1);
M[k<<1]=(rage-(rage>>1))*tag[k];
M[k<<1|1]=(rage>>1)*tag[k];
tag[k]=0;
}
void add(int k,int x,int y,int v)
{
pushdown(k);
int l=ls[k],r=rs[k],mid=(l+r)>>1;
if(x==l&&y==r)
{
tag[k]=v;
M[k]=v*(r-l+1);
return;
}
if(x<=mid) add(k<<1,x,min(y,mid),v);
if(y>mid) add(k<<1|1,max(x,mid+1),y,v);
M[k]=M[k<<1]+M[k<<1|1];
}
int query(int k,int x,int y)
{
pushdown(k);
int l=ls[k],r=rs[k],mid=(l+r)>>1,ans=0;
if(x==l&&y==r) return M[k];
if(x<=mid)ans+=query(k<<1,x,min(y,mid));
if(y>mid)ans+=query(k<<1|1,max(x,mid+1),y);
return ans;
}
int main()
{
int T,ca=1;
for(T=read();T;T--)
{
int l,r,v,n,m;
n=read();m=read();
build(1,1,n);
while(m--)
{
scanf("%d%d%d",&l,&r,&v);
add(1,l,r,v);
}
printf("Case %d: The total value of the hook is %d.\n",ca++,query(1,1,n));
}
return 0;
}

Just a Hook (HDU 1698) 懒惰标记的更多相关文章

  1. hdu 1698 (延迟标记+区间修改+区间求和)

    In the game of DotA, Pudge's meat hook is actually the most horrible thing for most of the heroes. T ...

  2. E - Just a Hook - hdu 1698(区间覆盖)

    某个英雄有这样一个金属长棍,这个金属棍有很多相同长度的短棍组成,大概最多有10w节,现在这个人有一种魔法,他可以把一段区间的金属棍改变成别的物质,例如金银或者铜, 现在他会有一些操作在这个金属棍上,他 ...

  3. E - Just a Hook HDU - 1698 线段树区间修改区间和模版题

    题意  给出一段初始化全为1的区间  后面可以一段一段更改成 1 或 2 或3 问最后整段区间的和是多少 思路:标准线段树区间和模版题 #include<cstdio> #include& ...

  4. Just a Hook HDU - 1698Just a Hook HDU - 1698 线段树区间替换

    #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> us ...

  5. HDU 1698 just a hook - 带有lazy标记的线段树(用结构体实现)

    2017-08-30 18:54:40 writer:pprp 可以跟上一篇博客做个对比, 这种实现不是很好理解,上一篇比较好理解,但是感觉有的地方不够严密 代码如下: /* @theme:segme ...

  6. HDU 1698 Just a Hook(线段树成段更新)

    题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=1698 题目: Problem Description   In the game of DotA, P ...

  7. HDU 1698 Just a Hook(线段树:区间更新)

    http://acm.hdu.edu.cn/showproblem.php?pid=1698 题意:给出1~n的数,每个数初始为1,每次改变[a,b]的值,最后求1~n的值之和. 思路: 区间更新题目 ...

  8. HDU 1698 Just a Hook (线段树区间更新)

    题目链接 题意 : 一个有n段长的金属棍,开始都涂上铜,分段涂成别的,金的值是3,银的值是2,铜的值是1,然后问你最后这n段总共的值是多少. 思路 : 线段树的区间更新.可以理解为线段树成段更新的模板 ...

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

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

随机推荐

  1. JavaScript代码优化新工具UglifyJS

    jQuery 1.5 发布的时候 john resig 大神说所用的代码优化程序从Google Closure切换到UglifyJS,新工具的压缩效果非常令人满意. UglifyJS 是一个服务端no ...

  2. 栗染-Jsp编码常见问题

    如图在我们新建一个jsp的时候想给自己的页面加一个中文就会出现如图所示的问题 遇到这种情况一般是选第二个或者 将<%@ page language="java" import ...

  3. 键盘按钮keyCode大全:获取按键对应的键值的方法

    没有大全,只有方法,授人与鱼不如授人于渔: 下面这行代码,大家可以打在控制台里,直接进行测试: document.body.onkeyup = function (e) { e = e || wind ...

  4. [Qt Creator 快速入门] 第1章 Qt Creator简介

    Qt Creator 是一个跨平台的.完整的 Qt 集成开发环境,其中包括了高级C++代码编辑器.项目和生成管理工具.集成的上下文相关的帮助系统.图形化调试器.代码管理和浏览工具等.这一章先对 Qt ...

  5. 计算误差——ACM计算几何中的精度问题

    浮点数为何会有精度问题   占字节数 数值范围 十进制精度位数 float 4 -3.4e-38~3.4e38 6~7 double 8 -1.7e-308~1.7e308 14~15 如果内存不是很 ...

  6. Ant安装以及环境配置以及使用[windows环境]

    一.安装ant 官方主页http://ant.apache.org下载新版的ant. *下载对应的版本,解压到我们的硬盘. 二.配置环境变量 Window中设置ant环境变量: ANT_HOME    ...

  7. node-rsa加密,java解密调试

    用NODE RSA JS 加密解密正常,用JAVA RSAUtils工具类加密解密正常.但是用node加密玩的java解密不了.原因:node默认的是 DEFAULT_ENCRYPTION_SCHEM ...

  8. LN : JSON (利用C++实现JSON)

    Appreciation to our TA, 王毅峰, who designed this task. 问题描述 JSON, JavaScript Object Notation,is an fle ...

  9. 往文件内写入内容(java)

    新建个工具类,并标记成静态的,方便调用. package util; import java.io.File;import java.io.FileOutputStream; public class ...

  10. bash 博弈

    转载并修改自: http://www.cnblogs.com/wulangzhou/archive/2013/03/14/2959660.html 简单的取拿游戏一堆石子(或者其它的什么东西),下面是 ...