HDU 1698 Just a Hook(线段树区间替换)
Just a Hook
Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 27359    Accepted Submission(s): 13593
Now Pudge wants to do some operations on the hook.
Let us number the consecutive metallic sticks of the hook from 1 to N. For each operation, Pudge can change the consecutive metallic sticks, numbered from X to Y, into cupreous sticks, silver sticks or golden sticks.
The total value of the hook is calculated as the sum of values of N metallic sticks. More precisely, the value for each kind of stick is calculated as follows:
For each cupreous stick, the value is 1.
For each silver stick, the value is 2.
For each golden stick, the value is 3.
Pudge wants to know the total value of the hook after performing the operations.
You may consider the original hook is made up of cupreous sticks.
For each case, the first line contains an integer N, 1<=N<=100,000, which is the number of the sticks of Pudge’s meat hook and the second line contains an integer Q, 0<=Q<=100,000, which is the number of the operations.
Next Q lines, each line contains three integers X, Y, 1<=X<=Y<=N, Z, 1<=Z<=3, which defines an operation: change the sticks numbered from X to Y into the metal kind Z, where Z=1 represents the cupreous kind, Z=2 represents the silver kind and Z=3 represents
the golden kind.
10
2
1 5 2
5 9 3
把一个区间范围内的数字全部替换成另一个数字,最后求1-n的数字和,跟一般更新的线段树不太一样,这个是替换而不是更新,学习一下别人的写法。
代码:
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
#define INF 0x3f3f3f3f
#define MM(x,y) memset(x,y,sizeof(x))
#define LC(x) (x<<1)
#define RC(x) ((x<<1)|1)
#define MID(x,y) ((x+y)>>1)
typedef pair<int,int> pii;
typedef long long LL;
const int N=100010;
struct seg
{
int l,mid,r;
int sum,add;
};
seg T[N<<2];
void pushup(int k)
{
T[k].sum=T[RC(k)].sum+T[LC(k)].sum;
}
void pushdown(int k,int len)//pushdownÇø¼äÌæ»»µÄд·¨
{
if(T[k].add)
{
T[LC(k)].add=T[k].add;
T[RC(k)].add=T[k].add;
T[LC(k)].sum=T[k].add*(len-len/2);
T[RC(k)].sum=T[k].add*(len/2);
T[k].add=0;
}
}
void build(int k,int l,int r)
{
T[k].l=l;
T[k].r=r;
T[k].mid=MID(l,r);
T[k].add=0;
if(l==r)
T[k].sum=1;
else
{
build(LC(k),l,T[k].mid);
build(RC(k),T[k].mid+1,r);
pushup(k);
}
}
void update(int k,int l,int r,int val)
{
if(r<T[k].l||T[k].r<l)
return ;
if(l<=T[k].l&&r>=T[k].r)
{
T[k].add=val;
T[k].sum=val*(T[k].r-T[k].l+1);
}
else
{
pushdown(k,T[k].r-T[k].l+1);
if(l<=T[k].mid)
update(LC(k),l,r,val);
if(r>T[k].mid)
update(RC(k),l,r,val);
pushup(k);
}
}
int main(void)
{
int tcase,i,j,n,m,l,r,val;
scanf("%d",&tcase);
for (int q=1; q<=tcase; ++q)
{
scanf("%d",&n);
build(1,1,n);
scanf("%d",&m);
for (i=0; i<m; i++)
{
scanf("%d%d%d",&l,&r,&val);
update(1,l,r,val);
}
printf("Case %d: The total value of the hook is %d.\n",q,T[1].sum);
}
return 0;
}
HDU 1698 Just a Hook(线段树区间替换)的更多相关文章
- HDU 1698 Just a Hook(线段树 区间替换)
		
Just a Hook [题目链接]Just a Hook [题目类型]线段树 区间替换 &题解: 线段树 区间替换 和区间求和 模板题 只不过不需要查询 题里只问了全部区间的和,所以seg[ ...
 - [HDU] 1698 Just a Hook [线段树区间替换]
		
Just a Hook Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
 - HDU 1698 Just a Hook(线段树区间替换)
		
题目地址:pid=1698">HDU 1698 区间替换裸题.相同利用lazy延迟标记数组,这里仅仅是当lazy下放的时候把以下的lazy也所有改成lazy就好了. 代码例如以下: # ...
 - HDU.1689 Just a Hook (线段树 区间替换 区间总和)
		
HDU.1689 Just a Hook (线段树 区间替换 区间总和) 题意分析 一开始叶子节点均为1,操作为将[L,R]区间全部替换成C,求总区间[1,N]和 线段树维护区间和 . 建树的时候初始 ...
 - (简单) HDU 1698 Just a Hook , 线段树+区间更新。
		
Description: In the game of DotA, Pudge’s meat hook is actually the most horrible thing for most of ...
 - HDU 1698 Just a Hook(线段树区间更新查询)
		
描述 In the game of DotA, Pudge’s meat hook is actually the most horrible thing for most of the heroes ...
 - HDU 1698 Just a Hook 线段树区间更新、
		
来谈谈自己对延迟标记(lazy标记)的理解吧. lazy标记的主要作用是尽可能的降低时间复杂度. 这样说吧. 如果你不用lazy标记,那么你对于一个区间更新的话是要对其所有的子区间都更新一次,但如果用 ...
 - HDU 1698 just a hook 线段树,区间定值,求和
		
Just a Hook Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1 ...
 - HDU  1698 Just a Hook 线段树+lazy-target 区间刷新
		
Just a Hook Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
 - hdu - 1689 Just a Hook (线段树区间更新)
		
http://acm.hdu.edu.cn/showproblem.php?pid=1698 n个数初始每个数的价值为1,接下来有m个更新,每次x,y,z 把x,y区间的数的价值更新为z(1<= ...
 
随机推荐
- Java操作Session与Cookie
			
1,Java操作Session Java操作Session非常简单,步骤如下 1.1,在servlet中通过request获取session HttpSession session = request ...
 - Ajax案例(使用ajax进行加法运算)
			
此案例功能实现了一边看视频一边进行加法运算,而加法运算时页面不会刷新请求 ajax代码: <script type="text/javascript" src="j ...
 - Android之智能问答机器人
			
本文主要利用图灵机器人的接口,所做的一个简单的智能问答机器人 实现 由于发送与接收消息都是不同的listView,所以要用有两个listVeiw的布局文件 接收消息布局文件 <?xml vers ...
 - 学习hadoop,搭建hadoop遇到一些特殊问题
			
我执行下面步骤: 1. 动态增加DataNode节点和TaskTracker节点 以host9为例 在host9上执行: 指定主机名 vi /etc/hostname 指定主机名到IP地址的映射 ...
 - centos  截图命令  screenshot
			
[root@ok ~]# gnome-screenshot#全屏截图 [root@ok ~]# gnome-screenshot --interactive#自定义截图
 - 网站构建学习笔记(0)——基本概念了解及资源学习(copy自w3school)
			
一.学习方面 1.WWW - 万维网 什么是 WWW? WWW 指万维网(World Wide Web) 万维网常被称为Web Web 是由遍布全球的计算机所组成的网络 所有 Web 中的计算机都可以 ...
 - SQL_Server_2005_函数大全(描述及实例)
			
为了方便阅读,把函数分为四种类型,分别表述. SQL_Server_2005_字符串函数(描述及实例) 函数名称:ascii.char.charindex.difference.left.right. ...
 - 微信SDK开发学习
			
public class MainActivity extends Activity { // 应用程序的id,就是在网上开发平台创建应用的appid public static final Stri ...
 - http://jingyan.baidu.com/album/03b2f78c4cc0ad5ea337ae7d.html
			
http://jingyan.baidu.com/album/03b2f78c4cc0ad5ea337ae7d.html
 - Java 时间架构图
			
Java 的Calendar,Date,TimeZone,Locale和DateFormat的关系图如下: 说明: milliseconds表示毫秒. milliseconds = "实际时 ...