Just a Hook (HDU 1698) 懒惰标记
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) 懒惰标记的更多相关文章
- hdu 1698 (延迟标记+区间修改+区间求和)
In the game of DotA, Pudge's meat hook is actually the most horrible thing for most of the heroes. T ...
- E - Just a Hook - hdu 1698(区间覆盖)
某个英雄有这样一个金属长棍,这个金属棍有很多相同长度的短棍组成,大概最多有10w节,现在这个人有一种魔法,他可以把一段区间的金属棍改变成别的物质,例如金银或者铜, 现在他会有一些操作在这个金属棍上,他 ...
- E - Just a Hook HDU - 1698 线段树区间修改区间和模版题
题意 给出一段初始化全为1的区间 后面可以一段一段更改成 1 或 2 或3 问最后整段区间的和是多少 思路:标准线段树区间和模版题 #include<cstdio> #include& ...
- Just a Hook HDU - 1698Just a Hook HDU - 1698 线段树区间替换
#include<cstdio> #include<cstring> #include<iostream> #include<algorithm> us ...
- HDU 1698 just a hook - 带有lazy标记的线段树(用结构体实现)
2017-08-30 18:54:40 writer:pprp 可以跟上一篇博客做个对比, 这种实现不是很好理解,上一篇比较好理解,但是感觉有的地方不够严密 代码如下: /* @theme:segme ...
- HDU 1698 Just a Hook(线段树成段更新)
题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=1698 题目: Problem Description In the game of DotA, P ...
- HDU 1698 Just a Hook(线段树:区间更新)
http://acm.hdu.edu.cn/showproblem.php?pid=1698 题意:给出1~n的数,每个数初始为1,每次改变[a,b]的值,最后求1~n的值之和. 思路: 区间更新题目 ...
- HDU 1698 Just a Hook (线段树区间更新)
题目链接 题意 : 一个有n段长的金属棍,开始都涂上铜,分段涂成别的,金的值是3,银的值是2,铜的值是1,然后问你最后这n段总共的值是多少. 思路 : 线段树的区间更新.可以理解为线段树成段更新的模板 ...
- HDU 1698——Just a Hook——————【线段树区间替换、区间求和】
Just a Hook Time Limit:2000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit ...
随机推荐
- UVaLive 6680 Join the Conversation (DP)
题意:给出n条发言,让你求最大的交流长度并输出标记顺序. 析:这个题要知道的是,前面的人是不能at后面的人,只能由后面的人at前面的,那就简单了,我们只要更新每一层的最大值就好,并不会影响到其他层. ...
- Rails5 layout 和 template
layout是布局,比如页面的头(head), 脚(foot), 内容(body) template是布局的一部分的内容 这两货实在太像了,写了这些我也是一脸懵逼. 换个说法,layout和tem ...
- SQL Server触发器创建、删除、修改、查看示例步骤
一﹕ 触发器是一种特殊的存储过程﹐它不能被显式地调用﹐而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活.所以触发器可以用来实现对表实施复杂的完整性约`束. 二﹕ SQL Server为每个触发 ...
- 【Linux】小米路由开启SSH访问权限
一.验证小米路由ROM是否为开发版 1. 登录小米路由Web管理页面,检查ROM版本是否为开发版(若为开发版直接跳至第二步,若为稳定版继续本步骤). 2. 进入小米路由器官网(http://www1 ...
- 【工具】---- json-server基本使用
一.概念 在开发过程中,前端通常需要等待后端开发完接口后,再调用接口渲染相应的数据,这会影响开发效率.而json-server的作用就是为了解决前后端并行开发的痛点,在本地模拟后端接口用来测试前端效果 ...
- c语言—栈区,堆区,全局区,文字常量区,程序代码区 详解
转:http://www.cnblogs.com/xiaowenhui/p/4669684.html 一.预备知识—程序的内存分配 一个由C/C++编译的程序占用的内存分为以下几个部分1.栈区(sta ...
- ADB Usage Complete / ADB 用法大全
ADB,即 Android Debug Bridge,它是 Android 开发/测试人员不可替代的强大工具,也是 Android 设备玩家的好玩具. 持续更新中,欢迎提 PR 和 Issue 补充指 ...
- 【转】数据倾斜是多么痛?spark作业/面试/调优必备秘籍
原博文出自于: http://sanwen.net/a/gqkotbo.html 感谢! 来源:数盟 调优概述 有的时候,我们可能会遇到大数据计算中一个最棘手的问题——数据倾斜,此时Spark作业的性 ...
- 计算给定数组 arr 中所有元素的总和的几种方法
1.forEach遍历: function sum(arr) { var result = 0; arr.forEach(function(item,index) { ...
- git删除本地分支失败,报错error: branch 'test219' not found.
错误: 删除本地分支报错,操作如下: git branch -d test219 操作失败,错误信息:error: branch 'test219' not found git branch -D t ...