1798. [AHOI2009]维护序列【线段树】
Description
Input
Output
Sample Input
1 2 3 4 5 6 7
5
1 2 5 5
3 2 4
2 3 7 9
3 1 3
3 4 7
Sample Output
35
8
HINT
【样例说明】
初始时数列为(1,2,3,4,5,6,7)。
经过第1次操作后,数列为(1,10,15,20,25,6,7)。
对第2次操作,和为10+15+20=45,模43的结果是2。
经过第3次操作后,数列为(1,10,24,29,34,15,16}
对第4次操作,和为1+10+24=35,模43的结果是35。
对第5次操作,和为29+34+15+16=94,模43的结果是8。
测试数据规模如下表所示
数据编号 1 2 3 4 5 6 7 8 9 10
N= 10 1000 1000 10000 60000 70000 80000 90000 100000 100000
M= 10 1000 1000 10000 60000 70000 80000 90000 100000 100000
线段树模板题
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
struct node
{
long long val;
long long mul;
long long add;
} Segt[+];
long long n,m,p,a[],INF; void build(long long node,long long a[],long long l,long long r)
{
Segt[node].add=;
Segt[node].mul=;//初始值要设正确
if (l==r)
Segt[node].val=a[l];
else
{
long long mid=(l+r)/;
build(node*,a,l,mid);
build(node*+,a,mid+,r);
Segt[node].val=(Segt[node*].val+Segt[node*+].val)%p;
}
} void Push(long long node,long long l,long long r)
{ if (Segt[node].mul!=)
{
//因为乘法可以影响区间的加法,但加法无法影响区间的乘法
//所以更新乘法的时候要把左右儿子的加法也乘上
Segt[node*].mul=(Segt[node*].mul*Segt[node].mul)%p;
Segt[node*+].mul=(Segt[node*+].mul*Segt[node].mul)%p;
Segt[node*].add=(Segt[node*].add*Segt[node].mul)%p;
Segt[node*+].add=(Segt[node*+].add*Segt[node].mul)%p; long long mid=(l+r)/;
Segt[node*].val=(Segt[node*].val*Segt[node].mul)%p;
Segt[node*+].val=(Segt[node*+].val*Segt[node].mul)%p;
Segt[node].mul=;
}
if (Segt[node].add!=)
{
Segt[node*].add=(Segt[node*].add+Segt[node].add)%p;
Segt[node*+].add=(Segt[node*+].add+Segt[node].add)%p;
long long mid=(l+r)/;
Segt[node*].val=(Segt[node*].val+Segt[node].add*(mid-l+))%p;
Segt[node*+].val=(Segt[node*+].val+Segt[node].add*(r-mid))%p;
Segt[node].add=;
}
} void MulUpdate(int node,int l,int r,int l1,int r1,int k)
{
if (r1<l || l1>r)
return;
if (l1<=l&&r<=r1)
{
Segt[node].val=(Segt[node].val*k)%p;
Segt[node].add=(Segt[node].add*k)%p;
Segt[node].mul=(Segt[node].mul*k)%p;
return;
}
Push(node,l,r);
long long mid=(l+r)/;
MulUpdate(node*,l,mid,l1,r1,k);
MulUpdate(node*+,mid+,r,l1,r1,k);
Segt[node].val=(Segt[node*].val+Segt[node*+].val)%p;
} void AddUpdate(long long node,long long l,long long r,long long l1,long long r1,long long k)
{
if (r1<l || l1>r)
return;
if (l1<=l&&r<=r1)
{
Segt[node].val=(Segt[node].val+k*(r-l+))%p;
Segt[node].add=(Segt[node].add+k)%p;
return;
}
Push(node,l,r);
long long mid=(l+r)/;
AddUpdate(node*,l,mid,l1,r1,k);
AddUpdate(node*+,mid+,r,l1,r1,k);
Segt[node].val=(Segt[node*].val+Segt[node*+].val)%p;
} long long Query(long long node,long long l,long long r,long long l1,long long r1)
{
if (l1>r||r1<l)
return ;
if (l1<=l&&r<=r1)
return Segt[node].val;
Push(node,l,r);
long long mid=(l+r)/;
return (Query(node*,l,mid,l1,r1)+Query(node*+,mid+,r,l1,r1))%p;
} int main()
{
long long x,y,k,h;
scanf("%lld%lld",&n,&p);
for (int i=; i<=n; ++i)
scanf("%lld",&a[i]);
scanf("%lld",&m);
build(,a,,n);
for (int i=; i<=m; ++i)
{
scanf("%lld",&h);
if (h==)
scanf("%lld%lld%lld",&x,&y,&k),MulUpdate(,,n,x,y,k);
if (h==)
scanf("%lld%lld%lld",&x,&y,&k),AddUpdate(,,n,x,y,k);
if (h==)
scanf("%lld%lld",&x,&y),printf("%lld\n",Query(,,n,x,y)%p);
}
}
1798. [AHOI2009]维护序列【线段树】的更多相关文章
- BZOJ1798[Ahoi2009]维护序列——线段树
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...
- [P2023][AHOI2009]维护序列(线段树)
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
- [AHOI2009]维护序列 (线段树)
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
- 洛谷 P2023 [AHOI2009]维护序列 || 线段树加法和乘法运算
原理倒是非常简单.设原数为x,加法的lazytag为b,乘法的lazytag为a,操作数为c,那么原式为ax+b,乘上c后(ax+b)c=(ac)*x+b*c,加上c后(ax+b)+c=ax+(b+c ...
- [BZOJ1798][AHOI2009]Seq维护序列 线段树
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798 一眼看过去线段树,事实上就是线段树.对于乘和加的两个标记,我们可以规定一个顺序,比如 ...
- BZOJ 1798 AHOI2009 Seq 维护序列 线段树
题目大意:维护一个序列,提供三种操作: 1.将区间中每个点的权值乘上一个数 2.将区间中每个点的权值加上一个数 3.求一段区间的和对p取模的值 2631的超^n级弱化版.写2631之前能够拿这个练练手 ...
- 【AHOI2009】 维护序列 - 线段树
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
- 洛谷 P2023 BZOJ 1798 [AHOI2009]维护序列
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
- 洛谷 P2023 维护序列——线段树
先上一波题目 https://www.luogu.org/problem/P2023 复习了一波线段树 题目涉及的操作有区间加 区间乘以及区间求和 tips:线段树在传标记的时候 优先传乘法标记再传加 ...
随机推荐
- Spring系列之——Spring事务以及两大核心IOC和AOP
1 Spring事务 1.1 Spring事务是什么(百度) 事务是对一系列的数据库操作(比如插入多条数据)进行统一的提交或是回滚操作,如果插入成功,那么一起成功,如果中间一条出现异常,那么回滚之前的 ...
- Redis到底是多线程还是单线程?线程安全吗
redis是单线程,线程安全 redis可以能够快速执行的原因: (1) 绝大部分请求是纯粹的内存操作(非常快速)(2) 采用单线程,避免了不必要的上下文切换和竞争条件(3) 非阻塞IO - IO多路 ...
- hdu Rescue 1242
Rescue Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- POJ2251(KB1-B 三维BFS)
Dungeon Master Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 40872 Accepted: 19936 Desc ...
- android studio 加载libs
eclipse 项目转 android studio libs 不能加载 导致不能导入 记录下:libs 放在和src 同路径 dependencies:增加 compile files('libs ...
- CSS3 选择器用法小结
表单选择器: /*:enabled 可用的 :disabled 被禁用的 :focus 获取了焦点的 多用在表单元素上*/ input:enabled {...} input:disabled {.. ...
- java 方法重写和属性重写
重写,子类对父类方法不满意,重写,但这是重写,要与父类的方法一模一样.方法名相同:参数列表相同:返回值相同或子类的返回值是父类返回值的子类型,父类是long,子类是int也不可以,因为父类引用指向子类 ...
- 9.Java注解(Annotation)
一.系统内置标准注解 1.@Override 是一个标记注解类型,它被用作标注方法. 它说明了被标注的方法重载了父类的方法,起到了断言的作用.如果我们使用了这种Annotation在一个没有覆盖父类方 ...
- AIX常用命令学习(一)
1.prtconf命令 查看AIX主机的结构特征状态 语法: prtconf [ -c ] [ -k ] [ -L ] [ -m ] [ -s ] [ -v ] Flags: -c Displays ...
- mac os maverick下安装nginx+php-fpm via homebrew
自己虽然平时爱折腾,却很少有记下来的习惯,除非碰到特别多问题的部署才会有冲动.今天看同事折腾git,在旁边看着他mac上的evernote满满的记了好几篇,全是技术相关的记录,忽然很感慨.过去解决了很 ...