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. Create schema error (unknown database schema '')

    Andrey Devyatka 4 years ago Permalink Raw Message Hi,Please tell me, can I use the static library in ...

  2. vue中子组件向父组件传值

    1.子组件$emit()触发,父组件$on()监听 子组件:<template> <div class="hello"> <button v-on:c ...

  3. hdu2033

    http://acm.hdu.edu.cn/showproblem.php?pid=2033 1 #include<stdio.h> #include<string.h> #i ...

  4. ACM_括号匹配

    括号匹配(栈) Time Limit: 2000/1000ms (Java/Others) Problem Description: 给一组包含[]()两种括号的序列,检查是否是合法的. 如:()[] ...

  5. 287 Find the Duplicate Number 寻找重复数

    一个长度为 n + 1 的整形数组,其中的数字都在 1 到 n 之间,包括 1 和 n ,可知至少有一个重复的数字存在.假设只有一个数字重复,找出这个重复的数字.注意:    不能更改数组内容(假设数 ...

  6. C#基础 进制转换6/17

    二进制→十进制: 计算公式:a*20+b*21+c*22+…+m*2(n-1) 公式中a为二进制数右边第一位数,b为第二位数,以此类推 例:二进制1011010转换为十进制数为 0*20+1*21+0 ...

  7. VMware workstation 14 CentOs 7.5.1804 虚拟机网卡设置为NAT模式并设置固定IP

    一.背景知识     虚拟机网络模式 无论是vmware workstation,virtual box,virtual pc等虚拟机软件,一般来说,虚拟机有三种网络模式: 1.桥接 2.NAT 3. ...

  8. CentOS 7.4 下搭建 Elasticsearch 6.3 搜索群集

    上个月 13 号,Elasticsearch 6.3 如约而至,该版本和以往版本相比,新增了很多新功能,其中最令人瞩目的莫过于集成了 X-Pack 模块.而在最新的 X-Pack 中 Elastics ...

  9. droid开发:如何打开一个.dcm文件作为位图?

    我目前正在做一个Android应用程序的DICOM 继code打开图片DROM RES /绘制的“ussual”图像格式,但它不与.dcm工作 公共类BitmapView扩展视图 { 公共Bitmap ...

  10. [算法天天练] - C语言实现约瑟夫环(2)

    Linux下 #include <stdlib.h>#include <stdio.h> int main(){ int n,m,i,s = 0; printf("E ...