hdu 1698 线段树成段更新
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1698
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <iostream>
#include <cstring>
#include <queue>
#include <vector> #define maxn 130050
#define lson l,mid,u<<1
#define rson mid+1,r,u<<1|1
using namespace std; const int INF = 0x3f3f3f; int seg[maxn<<];
int pau[maxn<<]; void Push_UP(int u){
seg[u] =seg[u<<] + seg[u<<|];
}
void Push_Down(int l,int r,int u){
if(pau[u]){
int mid = (l + r)/;
pau[u<<] = pau[u<<|] = pau[u];
seg[u<<] = (mid - l + ) * pau[u];
seg[u<<|] = (r - mid) * pau[u];
pau[u] = ;
}
}
void build(int l,int r,int u){
if(l == r){
seg[u] = ;
return;
}
int mid = (l + r)/;
build(lson);
build(rson);
Push_UP(u);
}
void Update(int L,int R,int num,int l,int r,int u){
if(L <= l && r <= R){ // 这个地方要注意!!
pau[u] = num;
seg[u] = num * (r - l + );
return;
}
Push_Down(l,r,u);
int mid = (l + r)/;
if(L <= mid) Update(L,R,num,lson);
if(R > mid) Update(L,R,num,rson);
Push_UP(u);
} int main()
{
if(freopen("input.txt","r",stdin)== NULL) {printf("Error\n"); exit();}
int T;
cin>>T;
for(int t=;t<=T;t++){
int N,Q;
cin>>N;
build(,N,);
cin>>Q;
memset(pau,,sizeof(pau));
while(Q--){
int X,Y,Z;
scanf("%d%d%d",&X,&Y,&Z);
Update(X,Y,Z,,N,);
}
printf("Case %d: The total value of the hook is %d.\n",t,seg[]);
}
}
hdu 1698 线段树成段更新的更多相关文章
- hdu 1698 线段树 成段更新
		
题意:一段钩子,每个钩子的值为1,有若干更新,每次跟新某段的值,若干查询某段的和 基础题了 #include<cstdio> #include<iostream> #inclu ...
 - hdu 4747【线段树-成段更新】.cpp
		
题意: 给出一个有n个数的数列,并定义mex(l, r)表示数列中第l个元素到第r个元素中第一个没有出现的最小非负整数. 求出这个数列中所有mex的值. 思路: 可以看出对于一个数列,mex(r, r ...
 - HDU 3577 Fast Arrangement ( 线段树 成段更新 区间最值 区间最大覆盖次数 )
		
线段树成段更新+区间最值. 注意某人的乘车区间是[a, b-1],因为他在b站就下车了. #include <cstdio> #include <cstring> #inclu ...
 - ACM: Copying Data 线段树-成段更新-解题报告
		
Copying Data Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Description W ...
 - Codeforces Round #149 (Div. 2) E. XOR on Segment (线段树成段更新+二进制)
		
题目链接:http://codeforces.com/problemset/problem/242/E 给你n个数,m个操作,操作1是查询l到r之间的和,操作2是将l到r之间的每个数xor与x. 这题 ...
 - POJ 2777 Count Color (线段树成段更新+二进制思维)
		
题目链接:http://poj.org/problem?id=2777 题意是有L个单位长的画板,T种颜色,O个操作.画板初始化为颜色1.操作C讲l到r单位之间的颜色变为c,操作P查询l到r单位之间的 ...
 - HDU1698_Just a Hook(线段树/成段更新)
		
解题报告 题意: 原本区间1到n都是1,区间成段改变成一个值,求最后区间1到n的和. 思路: 线段树成段更新,区间去和. #include <iostream> #include < ...
 - poj 3468 A Simple Problem with Integers 【线段树-成段更新】
		
题目:id=3468" target="_blank">poj 3468 A Simple Problem with Integers 题意:给出n个数.两种操作 ...
 - POJ3468_A Simple Problem with Integers(线段树/成段更新)
		
解题报告 题意: 略 思路: 线段树成段更新,区间求和. #include <iostream> #include <cstring> #include <cstdio& ...
 
随机推荐
- C# 面向对象编程的继承性-多继承
			
多继承 如果要使用多继承,需要使用接口,因为C#中的类只支持单继承,而接口支持多继承,实现多继承时,继承的多个接口中间用逗号(,)隔开. 说明: 实现多继承时,继承的可以是多个接口,也可以是一个类及多 ...
 - mac 连接linux
			
1.ssh 通过ssh 的方式直接连接linux ssh name@ip -22 例:ssh zyc@192.168.1.100 -22 这个的前提是linux 要开启ssh 服务 先看一下linu ...
 - 80端口被占用 PID = 4解决办法
			
请按照下面的步骤来运行命令:1. sc config http stat = demand2. reboot3. run the command(netsh http show servicestat ...
 - SQL Server Analysis Services 数据挖掘(1)
			
来源: http://technet.microsoft.com/zh-cn/library/dn633476.aspx 假如你有一个购物类的网站,那么你如何给你的客户来推荐产品呢?这个功能在很多 电 ...
 - Chrome 中的彩蛋——T-Rex
			
今天,从网页上看到chrome的T-Rex的彩蛋,眨眼间完了10分钟.分享出来,只是好玩. 当 Chrome 无法连接到互联网时,或者上着网突然掉线,刷新页面时报错,我们都会看到T-Rex的身影,没错 ...
 - 百度分享 ajax 或分页后显示不出问题解决方案
			
自从用了AJAX后,JS重新加载问题就如家常便饭般层出不穷啊.没有系统学习过js感觉亚历山大. 百度后,还是找到了解决办法. 百度分享创建了一个全局对象window._bd_share_main.通过 ...
 - 一个基于nodejs,支持http/https的中间人(MITM)代理,便于渗透测试和开发调试。
			
源码地址:https://github.com/wuchangming/node-mitmproxy node-mitmproxy node-mitmproxy是一个基于nodejs,支持http/h ...
 - Linux——搭建PHP开发环境第四步:composer
			
原文链接:https://my.oschina.net/jiangbianwanghai/blog/473249 1.下载composer.phar [root#localhost opt]# cur ...
 - 设计模式——如何避免在OO设计中违反依赖倒置原则
			
1 变量不可以包含具体类的引用.一旦new,就对具体类产生依赖,用工厂模式来避开. 2 类不要派生至具体类.用派生抽象类避开. 3 不要覆盖基类已经实现的方法.基类中已实现的方法应该由所有子类共享.
 - hbase 0.96 单机伪分布式配置文件及遇到的问题 find命令
			
http://www.apache.org/dyn/closer.cgi/hbase/ 国外的站点下载速度慢,可以考虑国内的镜像网站~ 前面已经部署好了hadoop2.2.0单机伪分布式.必须先安装h ...