洛谷P3372

 //线段树  询问区间和,支持区间修改
#include <cstdio> using namespace std; struct treetype
{
int l,r;
long long sum,d;
}; const int maxn=; treetype a[maxn<<];
long long num[maxn]; void build(int k,int l,int r)
{
a[k].l=l;a[k].r=r;a[k].d=;
if (a[k].l==a[k].r)
{
a[k].sum=num[l];
return;
}
int mid=(l+r)>>,i=k<<;
build(i,l,mid);
build(i+,mid+,r);
a[k].sum=a[i].sum+a[i+].sum;
}
void pushdown(int k)
{
if (a[k].l==a[k].r) a[k].d=;
if (a[k].d==) return;
//int i=k<<1;long long t=a[i].r-a[i].l+1;a[i].sum+=t*a[k].d;a[i].d+=a[k].d;
//i++;t=a[i].r-a[i].l+1;a[i].sum+=t*a[k].d;a[i].d+=a[k].d;
int i=k<<;a[i].sum+=(a[i].r-a[i].l+)*a[k].d;a[i].d+=a[k].d;
i++;a[i].sum+=(a[i].r-a[i].l+)*a[k].d;a[i].d+=a[k].d;
a[k].d=;
}
void change(int k,int l,int r,long long d)
{
pushdown(k);
if (l<=a[k].l && a[k].r<=r)
{
//long long t=a[k].r-a[k].l+1;
a[k].sum+=(a[k].r-a[k].l+)*d;a[k].d=d;
return;
}
int mid=(a[k].l+a[k].r)>>,i=k<<;
if (l<=mid) change(i,l,r,d);
if (mid<r) change(i+,l,r,d);
a[k].sum=a[i].sum+a[i+].sum;
}
long long query(int k,int l,int r)
{
pushdown(k);
if (l<=a[k].l && a[k].r<=r) return a[k].sum;
int mid=(a[k].l+a[k].r)>>,i=k<<;
long long ans=;
if (l<=mid) ans=query(i,l,r);
if (mid<r) ans+=query(i+,l,r);
return ans;
} int main()
{
int n,m;
scanf("%d%d",&n,&m);
for (int i=;i<=n;i++) scanf("%lld",&num[i]);
build(,,n);
for (int i=;i<=m;i++)
{
int p,x,y;
scanf("%d%d%d",&p,&x,&y);
if (p==)
{
long long k;
scanf("%lld",&k);
change(,x,y,k);
}
else printf("%lld\n",query(,x,y));
}
return ;
}

poj3468

 //线段树  询问区间和,支持区间修改
#include <cstdio> using namespace std; struct treetype
{
int l,r;
long long sum,d;
}; const int maxn=; treetype a[maxn<<];
long long num[maxn]; void build(int k,int l,int r)
{
a[k].l=l;a[k].r=r;a[k].d=;
if (a[k].l==a[k].r)
{
a[k].sum=num[l];
return;
}
int mid=(l+r)>>,i=k<<;
build(i,l,mid);
build(i+,mid+,r);
a[k].sum=a[i].sum+a[i+].sum;
}
void pushdown(int k)
{
if (a[k].l==a[k].r) a[k].d=;
if (a[k].d==) return;
int i=k<<;a[i].sum+=(a[i].r-a[i].l+)*a[k].d;a[i].d+=a[k].d;
i++;a[i].sum+=(a[i].r-a[i].l+)*a[k].d;a[i].d+=a[k].d;
a[k].d=;
}
void change(int k,int l,int r,long long d)
{
pushdown(k);
if (l<=a[k].l && a[k].r<=r)
{
a[k].sum+=(a[k].r-a[k].l+)*d;a[k].d=d;
return;
}
int mid=(a[k].l+a[k].r)>>,i=k<<;
if (l<=mid) change(i,l,r,d);
if (mid<r) change(i+,l,r,d);
a[k].sum=a[i].sum+a[i+].sum;
}
long long query(int k,int l,int r)
{
pushdown(k);
if (l<=a[k].l && a[k].r<=r) return a[k].sum;
int mid=(a[k].l+a[k].r)>>,i=k<<;
long long ans=;
if (l<=mid) ans=query(i,l,r);
if (mid<r) ans+=query(i+,l,r);
return ans;
} int main()
{
int n,m;
scanf("%d%d",&n,&m);
for (int i=;i<=n;i++) scanf("%lld",&num[i]);
build(,,n);
for (int i=;i<=m;i++)
{
char p;scanf("%c",&p);
int x,y;
scanf("%c%d%d",&p,&x,&y);
if (p=='C')
{
long long k;
scanf("%lld",&k);
change(,x,y,k);
}
else printf("%lld\n",query(,x,y));
}
return ;
}

洛谷P3372/poj3468(线段树lazy_tag)(询问区间和,支持区间修改)的更多相关文章

  1. 洛谷P3373 [模板]线段树 2(区间增减.乘 区间求和)

    To 洛谷.3373 [模板]线段树2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格 ...

  2. 【洛谷】【线段树】P3353 在你窗外闪耀的星星

    [题目描述:] /* 飞逝的的时光不会模糊我对你的记忆.难以相信从我第一次见到你以来已经过去了3年.我仍然还生动地记得,3年前,在美丽的集美中学,从我看到你微笑着走出教室,你将头向后仰,柔和的晚霞照耀 ...

  3. 【洛谷】【线段树】P1886 滑动窗口

    [题目描述:] 现在有一堆数字共N个数字(N<=10^6),以及一个大小为k的窗口.现在这个从左边开始向右滑动,每次滑动一个单位,求出每次滑动后窗口中的最大值和最小值. [输入格式:] 输入一共 ...

  4. 洛谷P3374(线段树)(询问区间和,支持单点修改)

    洛谷P3374 //询问区间和,支持单点修改 #include <cstdio> using namespace std; ; struct treetype { int l,r,sum; ...

  5. 【洛谷】【线段树】P1471 方差

    [题目背景:] 滚粗了的HansBug在收拾旧数学书,然而他发现了什么奇妙的东西. [题目描述:] 蒟蒻HansBug在一本数学书里面发现了一个神奇的数列,包含N个实数.他想算算这个数列的平均数和方差 ...

  6. 洛谷P5280 [ZJOI2019]线段树

      https://www.luogu.org/problemnew/show/P5280 省选的时候后一半时间开这题,想了接近两个小时的各种假做法,之后想的做法已经接近正解了,但是有一些细节问题理不 ...

  7. 【洛谷】【线段树】P1047 校门外的树

    [题目描述:] 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……,L ...

  8. 洛谷 - P1198 - 最大数 - 线段树

    https://www.luogu.org/problemnew/show/P1198 要问区间最大值,肯定是要用线段树的,不能用树状数组.(因为没有逆元?但是题目求的是最后一段,可以改成类似前缀和啊 ...

  9. 洛谷 P2391 白雪皑皑 线段树+优化

    题目描述: 现在有 \(N\) 片雪花排成一列. Pty 要对雪花进行$ M $次染色操作,第 \(i\)次染色操作中,把\((i*p+q)%N+1\) 片雪花和第\((i*q+p)%N+1\)片雪花 ...

随机推荐

  1. day35—JavaScript操作元素(创建、删除)

    转行学开发,代码100天——2018-04-20 JavaScript对DOM元素的创建.删除操作. 1.创建DOM元素 appendChild方法 createElement(ochild); op ...

  2. Jenkins使用六:搭建流水线任务

    流水线可以把多个任务串起来,比如发布版本的一系列流程 配置流水线任务 构建语法为Groovy,执行3次test(job名) node { stage("test") { echo ...

  3. 关于狗书《Flask web开发 基于python的Web开发应用实战》中加入用户隐私功能

    目前是第二次撸狗书,在用户页面这一块我个人觉得有些问题(基于交互设计).按理来说,我作为一个权限只有User的个人用户来说,肯定不喜欢让别人看到我的真实姓名,地址之类的敏感信息.所以我应该是可以设置成 ...

  4. package和import语句_4

    J2SDK中主要的包介绍   java.lang—包含一些Java语言的核心类,如String.Math.Integer.System和 Thread,提供常用功能. java.awt—包含了构成抽象 ...

  5. HTML5--sessionStorage、localStorage、manifest

    sessionStroage: <!DOCTYPE html> <html lang="en"> <head> <meta charset ...

  6. ubuntu下可用的串口调试工具--cutecom

    今天在ubuntu下要用到串口发送16进制数据,百度了很多工具,觉得minicom和cutecom都不错,比较直观是cutecom,所以就介绍下cutecom. 安装: 输入 $ sudo apt-g ...

  7. phpcms批量更新内容页只更新一点就返回问题

    phpcms批量更新内容页只更新一点就返回问题 给caches目录增加写入权限

  8. vs code配置C/C++开发环境

    第一步:下载 Vs Code 点击链接下载Vs Code 下载版本  并安装 https://code.visualstudio.com/ 点击 Download for Windwos 安装时  如 ...

  9. MySQL基础(查)

    #新建一个表create database exercise; #查询表的信息SELECT * FROM student;SELECT * FROM score; #查询student表的第二条到第四 ...

  10. CentOS删除Applications中的菜单项

    有时候会错误的安装一些软件,可能安装被不成功,但是在左上角的Applications菜单中还是会显示出来,让人很不爽. 现在介绍一个删除掉CentOS Applications中菜单项的方法: 1.安 ...