洛谷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. keras:InternalError: Failed to create session

    如题,keras出现以上错误,解决办法: 找到占用gpu的进程: nvidia-smi -q 杀死这些进程即可: xxxxx

  2. node后台fetch请求数据-Hostname/IP doesn't match certificate's altnames解决方法

    一.问题背景 基于express框架,node后台fetch请求数据,报错Hostname/IP doesn't match certificate's altnames..... require(' ...

  3. 深入浅出WPF(Binding篇1)

    Binding在业界的使用一直是音译而来的,称为"Binding".Binding的源是逻辑数据对象,目标则是UI层上面的控件对象.数据通过Binding送达UI层,被UI层展示出 ...

  4. C++学习笔记(三)--数组、字符串

    1.数组,C++中不允许数组的下标值为变量,只能是常量或者常量表达式,必须先定义后使用.数组赋初值几种常见方式: int a[] = {1,2,3,4,5}: int a[4] = {2,1,3,4} ...

  5. div在上一层容器居中的方法

    今天又学了一种新方法,其实不算新,只是我不知道而已,想想学了一年多,现在什么动效都能写点出来了,但是一些基础的东西还是掌握不好,所以我现在依然会一遍遍的复习h5和css3,这就是自学的坏处,不知道的东 ...

  6. java_第一年_JDBC(2)

    上篇说到,通过JDBC可实现java编程程序和mysql数据库进行连接并交互,而交互后所形成的结果集是通过ResultSet对象来操作的. 创建ResultSet对象: stmt = conn.cre ...

  7. MongoDB数据库-基础篇

    一使用mongodb 1.常用的命令 show dbs    显示数据库列表 use dbname    进入dbname数据库,大小写敏感,没有这个数据库也不要紧 show collections ...

  8. POI之Excel文档增删改查

    需要引用apache第三方lib库poi 支持xls.xlsx格式excel读写操作 package com.hua.excel; import java.io.File;import java.io ...

  9. JavaFX程序初次运行创建数据库并执行建表SQL

    在我的第一个JavaFX程序完成安装的时候才突然发现,不能要用这个软件还要手动执行Sql来建表吧? 于是我的想法是在Main程序中执行时检测数据库连接状况,如果没有检测到数据库或者连接异常,那么出现错 ...

  10. 20180209-os模块

    下面将学习关于os模块的相关操作 项目练习的目录结构如下:所有的操作都是基于os_exercise.py模块 1.获取当前的Python脚本的工作目录路径 os.getcwd() # 1.获取当前目录 ...