P3372 【模板】线段树 1 区间查询与区间修改
题目描述
如题,已知一个数列,你需要进行下面两种操作:
1.将某区间每一个数加上x
2.求出某区间每一个数的和
输入输出格式
输入格式:
第一行包含两个整数N、M,分别表示该数列数字的个数和操作的总个数。
第二行包含N个用空格分隔的整数,其中第i个数字表示数列第i项的初始值。
接下来M行每行包含3或4个整数,表示一个操作,具体如下:
操作1: 格式:1 x y k 含义:将区间[x,y]内每个数加上k
操作2: 格式:2 x y 含义:输出区间[x,y]内每个数的和
输出格式:
输出包含若干行整数,即为所有操作2的结果。
输入输出样例
5 5
1 5 4 2 3
2 2 4
1 2 3 2
2 3 4
1 1 5 1
2 1 4
11
8
20
说明
时空限制:1000ms,128M
数据规模:
对于30%的数据:N<=8,M<=10
对于70%的数据:N<=1000,M<=10000
对于100%的数据:N<=100000,M<=100000
(数据已经过加强^_^,保证在int64/long long数据范围内)
样例说明:

在这里提醒大家一点
如果你用的是Dev-c++的5.92版本的话,用%lld输入可能会发生运行时错误
这时候如果你确保你的程序百分百对的话,可以直接提交
如果你不放心自己的程序,可以把%lld改成%I64d(I是大写i)进行调试,这样就不会出错了
但是切记
提交到洛谷上的时候一定要写%lld!!!!!!
否则全部WA而不是RE
切记切记
(ps:cena评测系统也是%lld)
我的代码基本是由函数构成的
写法比较通俗易懂
大家可以参考一下
再教大家一个小技巧:
如果你想要大批量的吧int改为long long int 的话
可以使#define 语句
然后用查找替换功能
注意查找的时候 查找的是 int+空格
否则你的printf会变得非常美观(手动滑稽)
#include<iostream>
#include<cstdio>
#include<cstring>
#define lglg long long int
using namespace std;
const lglg MAXN=;
lglg n,m;
lglg ans=;
struct node
{
lglg l,r,w,f;
}tree[MAXN*];
inline void updata(lglg k)
{
tree[k].w=tree[k*].w+tree[k*+].w;
}
inline void build(lglg k,lglg ll,lglg rr)
{
tree[k].l=ll;tree[k].r=rr;
if(tree[k].l==tree[k].r)
{
scanf("%lld",&tree[k].w);
return ;
}
lglg m=(ll+rr)/;
build(k*,ll,m);
build(k*+,m+,rr);
updata(k);
}
inline void down(lglg k)
{
tree[k*].f+=tree[k].f;
tree[k*+].f+=tree[k].f;
tree[k*].w+=(tree[k*].r-tree[k*].l+)*tree[k].f;
tree[k*+].w+=(tree[k*+].r-tree[k*+].l+)*tree[k].f;
tree[k].f=;
}
inline void interval_change(lglg k,lglg ll,lglg rr,lglg v)
{
if(tree[k].l>=ll&&tree[k].r<=rr)
{
tree[k].w+=(tree[k].r-tree[k].l+)*v;
tree[k].f+=v;
return ;
}
if(tree[k].f) down(k);
lglg m=(tree[k].l+tree[k].r)/;
if(ll<=m) interval_change(k*,ll,rr,v);
if(rr>m) interval_change(k*+,ll,rr,v);
updata(k);
}
inline void interval_ask(lglg k,lglg ll,lglg rr)
{
if(tree[k].l>=ll&&tree[k].r<=rr)
{
ans+=tree[k].w;
return ;
}
if(tree[k].f) down(k);
lglg m=(tree[k].l+tree[k].r)/;
if(ll<=m)
interval_ask(k*,ll,rr);
if(rr>m)
interval_ask(k*+,ll,rr);
}
int main()
{
scanf("%lld",&n);
scanf("%lld",&m);
build(,,n);
while(m--)
{
lglg how;
scanf("%lld",&how);
if(how==)//区间增加
{
lglg x,y,v;
scanf("%lld%lld%lld",&x,&y,&v);
interval_change(,x,y,v);
}
else//区间求和
{
lglg x,y;
ans=;
scanf("%lld%lld",&x,&y);
interval_ask(,x,y);
printf("%lld\n",ans);
}
}
return ;
}
P3372 【模板】线段树 1 区间查询与区间修改的更多相关文章
- 题解报告:CODE[VS] 1082 线段树练习3(区间修改+区间查询)
题目描述 Description 给你N个数,有两种操作: 1:给区间[a,b]的所有数增加X 2:询问区间[a,b]的数的和. 输入描述 Input Description 第一行一个正整数n,接下 ...
- HDU 3974 Assign the task(DFS序+线段树单点查询,区间修改)
描述There is a company that has N employees(numbered from 1 to N),every employee in the company has a ...
- 线段树 (区间查询最大 区间求和 区间加)带lazy
; struct Segment_tree { struct Node { int val,Max,lazy; ]; void init() { lazy=son[]=son[]=Size=val=M ...
- HDOJ 题目3308 LCIS(线段树,区间查询,区间合并)
LCIS Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- 洛谷 P3368 【模板】树状数组 2(区间修改点查询)
题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数数加上x 2.求出某一个数的值 输入输出格式 输入格式: 第一行包含两个整数N.M,分别表示该数列数字的个数和操作的总个数. ...
- 洛谷P3373 [模板]线段树 2(区间增减.乘 区间求和)
To 洛谷.3373 [模板]线段树2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格 ...
- POJ 3468 A Simple Problem with Integers(线段树 成段增减+区间求和)
A Simple Problem with Integers [题目链接]A Simple Problem with Integers [题目类型]线段树 成段增减+区间求和 &题解: 线段树 ...
- hdu 1754 I Hate It (模板线段树)
http://acm.hdu.edu.cn/showproblem.php?pid=1754 I Hate It Time Limit: 9000/3000 MS (Java/Others) M ...
- 【LuoguP3038/[USACO11DEC]牧草种植Grass Planting】树链剖分+树状数组【树状数组的区间修改与区间查询】
模拟题,可以用树链剖分+线段树维护. 但是学了一个厉害的..树状数组的区间修改与区间查询.. 分割线里面的是转载的: ----------------------------------------- ...
随机推荐
- webpack 的编译原理
自从接触了react,vue 这两个框架,都会用到webpack这个打包工具.面试的时候,经常被问到知道webpack的编译原理吗? 可以简单的介绍一下.每每这个时候都被问的哑口无言,平时用的时候挺顺 ...
- linux:在vmware上模拟新加一个硬盘对其格式化分区
在实际情况中,很容易有系统硬盘空间不够,然后需要添加新硬盘情况:这里我用vmware来模拟实验: 一:在一个Linux vmware上创建一个虚拟硬盘 1.打开vmware,选择一个已经搭建好的l ...
- 51Nod 1717
链接 分析:对于任意一个数,它的约数总是成对出现的,但是对于完全平方数,它因为有两个约数不相等,所以只会出现奇数次,所以最终的结果就是减去完全平方数 #include "iostream&q ...
- 【USACO2017JAN】 Promotion Counting
[题目链接] 点击打开链接 [算法] 离散化 + dfs + 树状数组 [代码] #include<bits/stdc++.h> using namespace std; #define ...
- 非旋treap (BZOJ1895)
记个板子,还是挺好用的. #include <bits/stdc++.h> using namespace std; ]; int rt,n,m,l,r,x,A,B,C,t; struct ...
- sizeof()解析(原)
(一)基本概念 sizeof操作符以字节形式给出了其操作数的存储大小.操作数可以是一个表达式或括在括号内的类型名.操作数的存储大小由操作数的类型决定. (二)使用方法 1.用于数据类型 ...
- jQuery测试结果
您的回答: 1.下面哪种说法是正确的? 您的回答:jQuery 是 JavaScript 库 2.jQuery 使用 CSS 选择器来选取元素? 您的回答:正确 3.jQuery 的简写是? 您的回答 ...
- Linux和windows下执行sql脚本文件
利用 sqlplus 登录数据库之后 键入: @/全路径/文件名 即可执行*.sql 文件 例 假设有一个 test.sql 文件 所在路径是/home/oracle/ ...
- 图片加水印文字,logo。生成缩略图
简单JSP代码 图片加水银文字 try { String path = request.getRealPath("images\\01.jpg"); out.print(path) ...
- 斯坦福CS231n—深度学习与计算机视觉----学习笔记 课时2
课时2 计算机视觉历史回顾与介绍中 1966年是计算机视觉的诞生年. 视觉处理流程的第一步,是对简单的形状结构处理,边缘排列. 边缘决定了结构. David Marr写了一本非常有影响力的书,视觉是分 ...