【bzoj1798】维护序列
线段树维护两个标记。
*0的操作在实质上没有任何影响。
#include <cstdio>
#include <cctype>
#define rep(i,a,b) for (int i=(a);i<=(b);i++)
#define LL long long
#define lc (x<<1)
#define rc (x<<1|1)
#define siz(x) (tr[x].r-tr[x].l+1)
const int N=131072;
const int S=262144;
int n,p,m,a[N];
struct Tree {
int l,r;
int a,b; //tag(a,b): ax+b
int sum;
Tree(int _l=0,int _r=0) {
l=_l,r=_r;
a=1,b=0;
sum=0;
}
}tr[S];
int rd(void) {
int x=0,f=1; char c=getchar();
while (!isdigit(c)) {
if (c=='-') f=-1;
c=getchar();
}
while (isdigit(c)) {
x=x*10+c-'0';
c=getchar();
}
return x*f;
}
void Pushup(int x) {
tr[x].sum=(tr[lc].sum+tr[rc].sum)%p;
}
void Clear(int x) {
int a=tr[x].a,b=tr[x].b; if (a==1&&!b) return; tr[x].a=1,tr[x].b=0;
tr[lc].sum=((LL)a*tr[lc].sum+(LL)b*siz(lc))%p; tr[lc].a=(LL)a*tr[lc].a%p; tr[lc].b=((LL)a*tr[lc].b+b)%p;
tr[rc].sum=((LL)a*tr[rc].sum+(LL)b*siz(rc))%p; tr[rc].a=(LL)a*tr[rc].a%p; tr[rc].b=((LL)a*tr[rc].b+b)%p;
}
void Build(int x,int l,int r) {
tr[x]=Tree(l,r);
if (l!=r) {
int mid=(l+r)>>1;
Build(lc,l,mid);
Build(rc,mid+1,r);
Pushup(x);
}
else tr[x].sum=a[l];
}
void Modify(int x,int l,int r,int a,int b) {
if (l<=tr[x].l&&tr[x].r<=r) {
tr[x].sum=((LL)a*tr[x].sum+(LL)b*siz(x))%p;
tr[x].a=(LL)a*tr[x].a%p;
tr[x].b=((LL)a*tr[x].b+b)%p;
return;
}
Clear(x);
int mid=(tr[x].l+tr[x].r)>>1;
if (l<=mid)
Modify(lc,l,r,a,b);
if (mid<r)
Modify(rc,l,r,a,b);
Pushup(x);
}
int Query(int x,int l,int r) {
if (l<=tr[x].l&&tr[x].r<=r) return tr[x].sum;
Clear(x);
int sum=0; int mid=(tr[x].l+tr[x].r)>>1;
if (l<=mid) {
int t=Query(lc,l,r);
sum=(sum+t)%p;
}
if (mid<r) {
int t=Query(rc,l,r);
sum=(sum+t)%p;
}
return sum;
}
int main(void) {
#ifndef ONLINE_JUDGE
freopen("sd.in","r",stdin);
freopen("sd.out","w",stdout);
#endif
n=rd(),p=rd();
rep(i,1,n) a[i]=rd();
Build(1,1,n);
m=rd();
rep(i,1,m) {
int kd=rd(); int x,y,z;
switch (kd) {
case 1:
x=rd(),y=rd(),z=rd();
Modify(1,x,y,z,0);
break;
case 2:
x=rd(),y=rd(),z=rd();
Modify(1,x,y,1,z);
break;
case 3:
x=rd(),y=rd();
int res=Query(1,x,y);
printf("%d\n",res);
break;
}
}
return 0;
}
【bzoj1798】维护序列的更多相关文章
- BZOJ1798 维护序列seq
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 8058 Solved: 2964[Submit ...
- 【双标记线段树】bzoj1798维护序列seq
一.题目 描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列 ...
- bzoj1798 维护序列
Description 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...
- p2023&bzoj1798 维护序列
传送门(洛谷) 传送门(bzoj) 题目 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全 ...
- bzoj1798维护序列
题目链接 暴力数据结构之线段树$qwq$ 裸题直接敲板子 忘了啥时候写的了$qwq$ 直接上代码吧 /************************************************* ...
- BZOJ-1798 维护序列
线段树.支持区间加.区间乘.区间查询和. 标记下移还有取模要注意. var n,p,q,i,s,t:longint; a:int64; num,n1,n2,n3:array[0..500000] of ...
- BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 5504 Solved: 1937[Submit ...
- [AHOI 2009] 维护序列(线段树模板题)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小 ...
- bzoj 维护序列seq(双标记线段树)
Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 4184 Solved: 1518[Submit][Status][Discus ...
- BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )
线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...
随机推荐
- MySQL学习笔记——ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO) Enter password: E ...
- cut用法
cut命令用来剪下文本文件里的数据,文本文件可以是字段类型或是字符类型. cut - remove sections from each line of files 语法 cut OPTION... ...
- JQuery 支持 hide 和 show 事件的方法与分析
问题提出 JQuery不支持hide和show作为事件形式出现, 实际上这两个仅仅是JQuery对象的一个方法(fn): 有一类UI交互需求,根据一个DOM对象的或者显示对附属的DOM对象做相同操作 ...
- LuaXMLRPC笔记
XMLRPC XMLRPC 为以http为传输协议,使用xml格式化数据来执行远程过程调用, 区别于本地过程调用, 即发生在不同主机之间. 属于分布式计算的一种简单实现,比web service简单易 ...
- Linux下安装APache
1:在图形界面下下载apache 安装包,我下的是 httpd-2.2.9.tar.gz 源码安装包,地址是http://httpd.apache.org/download.cgi 2:用:gzip ...
- 使用 gulp 搭建前端环境入门篇(转载)
本文转载自: 使用 gulp 搭建前端环境入门篇
- 将Cocos2dX渲染到MFC窗口上
引用:http://www.cnblogs.com/windeer/archive/2012/11/18/2767750.html 引言 现在智能手机已经慢慢进入大众化,移动类应用开始火爆起来,游戏类 ...
- zTree插件之单选下拉菜单代码
<!--ztree树结构--> <link rel="stylesheet" type="text/css" href="asset ...
- flexigrid扩展(添加全选,格式化表单)
1.关于flexigrid的属性这里不多说,百度一大把. 这里主要说一个参数process process参数:编写对某一列进行自定义处理的函数 function 方法名(tddiv,pid){}// ...
- 互联网中级Javascript面试题
互联网中级Javascript面试题 1.实现一个函数clone,可以对JavaScript中的5种主要的数据类型(包括Number.String.Object.Array.Boolean)进行值复制 ...