BZOJ_1798_[AHOI2009]维护序列_线段树
BZOJ_1798_[AHOI2009]维护序列_线段树
题意:老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成。 有长为N的数列,不妨设为a1,a2,…,aN 。有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一段数全部加一个值; (3)询问数列中的一段数的和,由于答案可能很大,你只需输出这个数模P的值。
分析:线段树上要打两个标记。要注意下传的顺序。显然先乘后加和先加后乘是不一样的。我们发现如果是先加后乘的话更改子树值的式子里会出现除法。不妨规定任何时候都先乘后加。推出的式子即为
t[lson]=(t[lson]*mul[pos]+add[pos]*(mid-l+1))%p;
mul[lson]=(mul[lson]*mul[pos])%p;
add[lson]=(add[lson]*mul[pos]+add[pos])%p;
代码:
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
#define ls p<<1
#define rs p<<1|1
#define LL long long
#define N 100050
LL add[N<<2],t[N<<2],mul[N<<2],mod;
int a[N],n,m;
void bt(int l,int r,int p){
mul[p]=1;
if(l==r){
scanf("%lld",&t[p]);return ;
}
int mid=l+r>>1;
bt(l,mid,ls);bt(mid+1,r,rs);
t[p]=(t[ls]+t[rs])%mod;
}
void pud(int l,int r,int p){
int mid=l+r>>1;
if(add[p]==0&&mul[p]==1)return ;
t[ls]=(t[ls]*mul[p]+add[p]*(mid-l+1))%mod;
t[rs]=(t[rs]*mul[p]+add[p]*(r-mid))%mod;
mul[ls]=mul[ls]*mul[p]%mod;
mul[rs]=mul[rs]*mul[p]%mod;
add[ls]=(add[ls]*mul[p]+add[p])%mod;
add[rs]=(add[rs]*mul[p]+add[p])%mod;
mul[p]=1;add[p]=0;
}
void upad(int l,int r,int x,int y,int c,int p){
if(x<=l&&y>=r){
add[p]=(add[p]+c)%mod;
t[p]+=1ll*(r-l+1)*c;t[p]%=mod;
return ;
}
int mid=l+r>>1;
pud(l,r,p);
if(x<=mid)upad(l,mid,x,y,c,ls);
if(y>mid)upad(mid+1,r,x,y,c,rs);
t[p]=(t[ls]+t[rs])%mod;
}
void upmu(int l,int r,int x,int y,int c,int p){
if(x<=l&&y>=r){
mul[p]=mul[p]*c%mod;
add[p]=add[p]*c%mod;
t[p]=t[p]*c%mod;
return ;
}
pud(l,r,p);
int mid=l+r>>1;
if(x<=mid)upmu(l,mid,x,y,c,ls);
if(y>mid)upmu(mid+1,r,x,y,c,rs);
t[p]=(t[ls]+t[rs])%mod;
}
LL query(int l,int r,int x,int y,int p){
if(x<=l&&y>=r)return t[p];
int mid=l+r>>1;
LL re=0;
pud(l,r,p);
if(x<=mid)re=(re+query(l,mid,x,y,ls))%mod;
if(y>mid)re=(re+query(mid+1,r,x,y,rs))%mod;
return re;
}
int main(){
scanf("%d%lld",&n,&mod);
bt(1,n,1);
scanf("%d",&m);
int op,x,y,z;
for(int i=1;i<=m;i++){
scanf("%d",&op);
if(op==1){
scanf("%d%d%d",&x,&y,&z);
upmu(1,n,x,y,z,1);
}else if(op==2){
scanf("%d%d%d",&x,&y,&z);
upad(1,n,x,y,z,1);
}else{
scanf("%d%d",&x,&y);
printf("%lld\n",query(1,n,x,y,1));
}
}
}
BZOJ_1798_[AHOI2009]维护序列_线段树的更多相关文章
- 洛谷P2023 [AHOI2009]维护序列(线段树区间更新,区间查询)
洛谷P2023 [AHOI2009]维护序列 区间修改 当我们要修改一个区间时,要保证 \(ax+b\) 的形式,即先乘后加的形式.当将区间乘以一个数 \(k\) 时,原来的区间和为 \(ax+b\) ...
- 1798. [AHOI2009]维护序列【线段树】
Description 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...
- 【题解】洛谷P2023 [AHOI2009] 维护序列(线段树)
洛谷P2023:https://www.luogu.org/problemnew/show/P2023 思路 需要2个Lazy-Tag 一个表示加的 一个表示乘的 需要先计算乘法 再计算加法 来自你谷 ...
- BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )
线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...
- bzoj 1798: [Ahoi2009]Seq 维护序列seq 线段树 区间乘法区间加法 区间求和
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeO ...
- Bzoj 1798: [Ahoi2009]Seq 维护序列seq(线段树区间操作)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小可 ...
- BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 5504 Solved: 1937[Submit ...
- bzoj 1798: [Ahoi2009]Seq 维护序列seq (线段树 ,多重标记下放)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 7773 Solved: 2792[Submit ...
- 【BZOJ】1798: [Ahoi2009]Seq 维护序列seq 线段树多标记(区间加+区间乘)
[题意]给定序列,支持区间加和区间乘,查询区间和取模.n<=10^5. [算法]线段树 [题解]线段树多重标记要考虑标记与标记之间的相互影响. 对于sum*b+a,+c直接加上即可. *c后就是 ...
随机推荐
- jQuery插件学习基础
1.给jQuery添加全局的函数: $.zgz={ fn1:function(){ alert('我是刚设置的第一个全局函数') },fn2:function(){ alert('我是刚设置的第二个 ...
- 三种Tomcat集群方式的优缺点分析
三种Tomcat集群方式的优缺点分析 2009-09-01 10:00 kit_lo kit_lo的博客 字号:T | T 本文对三种Tomcat集群方式的优缺点进行了分析.三种集群方式分别是:使用D ...
- spring 整合 mybatis 中数据源的几种配置方式
因为spring 整合mybatis的过程中, 有好几种整合方式,尤其是数据源那块,经常看到不一样的配置方式,总感觉有点乱,所以今天有空总结下. 一.采用org.mybatis.spring.mapp ...
- Docker 生态概览
Docker 和容器技术的发展可谓是日新月异,本文试图以全局的视角来梳理一下 docker 目前的生态圈.既然是概览,所以不会涉及具体的技术细节. Docker 自从发布以来发生了很多的变化,并且有些 ...
- 14 Live CDs for Penetration Testing (Pen Test) and Forensic
http://www.ivizsecurity.com/blog/penetration-testing/live-cd-penetration-testing-pen/ Yesterday I wa ...
- 微信小程序入门三实战
微信小应用借鉴了很多web的理念,但是其与传统的webApp.微信公共号这些BS架构不同,他是CS架构,是客户端的程序 小程序开发实战--豆瓣电影 项目配置 -在app.jsop中进行简单配置 --n ...
- 浅谈C++ STL中的优先队列(priority_queue)
从我以前的博文能看出来,我是一个队列爱好者,很多并不是一定需要用队列实现的算法我也会采用队列实现,主要是由于队列和人的直觉思维的一致性导致的. 今天讲一讲优先队列(priority_queue),实际 ...
- 想做微信小程序第三方代理,各位觉得一键生成平台能赚到钱吗?
这几年生意不景气,这是很多人的共识.从2009年开始,各种专家就判断"明年经济是最差的一年."然后,这个明年,一直"明"到了2018年,到最后,我们发现,经济就 ...
- Java动态代理(一)
好久没有动笔了,最近想巩固一下自己的基础知识,最近听到一同事问为什么JDK动态代理不能代理类,一听感觉懵逼呀!自己好像也不能很好的描述出来,所以想用2篇文章来复习一下动态代理知识: 一.什么是静态代理 ...
- ActiveMQ的使用
ActiveMQ使用分为两大块:生产者和消费者 一.准备 项目导入jar包:activemq-all-5.15.3.jar 并buildpath 二.生产者 创建连接工厂 ActiveMQCon ...