BZOJ 1798: [Ahoi2009]Seq 维护序列seq (线段树乘法加法的混合操作)
题目:点击打开链接
大意:一个数组。三个操作。第一种是区间[a,b]每一个数乘乘,另外一种是区间[a,b]每一个数加c,第三种是查询[a,b]区间的和并对p取摸。
两种操作就不能简单的仅仅往下传标记。每次传乘法标记时。要把加法标记同一时候乘上乘法标记,比如某个区间先进来一个加法标记add。之后又进来一个乘法标记mul。
那么结果为(x + add) * mul = x * mul + add * mul。
这样向下传标记的时候就相对独立。递归边界更新加法标记之前先乘上该节点的mul。左右儿子down的时候先将儿子的add乘上本节点的mul。
最后说一下sum,比方本节点的存在加法标记x和乘法标记y,而且是先加上x,再乘上y,则左儿子的sum要更新为(sum+x)*y。因为乘法标记传到本节点的时候更新了加法标记,x = x*y,所以sum[o<<1] = (左区间的长度*x) + sum[o<<1]*y。
/**************************************************************
Problem: 1798
User: __ElemenT
Language: C++
Result: Accepted
Time:4676 ms
Memory:10184 kb
****************************************************************/ #include <cstdio>
#define lson o<<1, l, m
#define rson o<<1|1, m+1, r
typedef long long LL;
const int maxn = 100005; int n, a, b, c, k, q;
LL sum[maxn<<2], add[maxn<<2], mul[maxn<<2], p; void up(int o) {
sum[o] = (sum[o<<1]+sum[o<<1|1]) %p;
} void build(int o, int l, int r) {
add[o] = 0, mul[o] = 1;
if(l == r) {
scanf("%lld", &sum[o]);
return;
}
int m = (l+r) >> 1;
build(lson);
build(rson);
up(o);
} void down(int o, int len) {
// if(add[o] != 0 && mul[o] != 1) {
add[o<<1] = (add[o<<1] * mul[o] + add[o]) %p;
add[o<<1|1] = (add[o<<1|1] * mul[o] + add[o]) %p;
mul[o<<1] = mul[o<<1] * mul[o] %p;
mul[o<<1|1] = mul[o<<1|1] * mul[o] %p;
sum[o<<1] = (sum[o<<1] * mul[o] + add[o] * (len-(len>>1))) %p;
sum[o<<1|1] = (sum[o<<1|1] * mul[o] + add[o] * (len>>1)) %p;
add[o] = 0, mul[o] = 1;
// }
} void update(int o, int l, int r, int op) {
if(a <= l && r <= b) {
if(op == 1) {
add[o] = add[o]*c %p;
mul[o] = mul[o]*c %p;
sum[o] = sum[o]*c %p;
} else {
add[o] = (add[o] + c) %p;
sum[o] = (sum[o] + (LL)c*(r-l+1)) %p;
}
return;
}
down(o, r-l+1);
int m = (l+r) >> 1;
if(a <= m) update(lson, op);
if(m < b ) update(rson, op);
up(o);
} LL query(int o, int l, int r) {
if(a <= l && r <= b) return sum[o] %p;
down(o, r-l+1);
int m = (l+r) >> 1;
LL ans = 0;
if(a <= m) ans = query(lson);
if(m < b ) ans += query(rson);
return ans %p;
} int main()
{
scanf("%d%lld", &n, &p);
build(1, 1, n);
scanf("%d", &q);
while(q--) {
scanf("%d%d%d", &k, &a, &b);
if(k != 3) {
scanf("%d", &c);
update(1, 1, n, k);
} else printf("%lld\n", query(1, 1, n));
}
return 0;
}
BZOJ 1798: [Ahoi2009]Seq 维护序列seq (线段树乘法加法的混合操作)的更多相关文章
- 【BZOJ1798】【AHOI2009】维护序列(线段树)
题目链接 题解 这不就是luogu的线段树2的板子吗.... 没有任何的区别... 上代码吧... #include<iostream> #include<cstdio> #i ...
- 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 老师交给小可可一个维护数列的任务,现在小可 ...
- bzoj 1798: [Ahoi2009]Seq 维护序列seq (线段树 ,多重标记下放)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 7773 Solved: 2792[Submit ...
- 1798: [Ahoi2009]Seq 维护序列seq
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 2930 Solved: 1087[Submit ...
- BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 5504 Solved: 1937[Submit ...
- BZOJ_1798_[AHOI2009]维护序列_线段树
BZOJ_1798_[AHOI2009]维护序列_线段树 题意:老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: ( ...
- [AHOI 2009] 维护序列(线段树模板题)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小 ...
随机推荐
- Python 快排[pythonnic]
def QS(array): less = [] more = [] if len(array) <= 1: return array head = array.pop() for x in a ...
- Git——github高级
分支管理 分支不是越多越好,只求一个稳定的分支,即master不要轻易去更改 对应master要有一个开发者分支,保证mater分支的稳定性 所有的功能都在开发者分支上进行 在所有功能开发后新建发布分 ...
- dubbo之服务降级
向注册中心写入动态配置覆盖规则:(通过由监控中心或治理中心的页面完成) RegistryFactory registryFactory = ExtensionLoader.getExtensionLo ...
- axios方法封装
axios方法封装 一般情况下,我们会用到的方法有:GET,POST,PUT,PATCH,封装方法如下: 五.封装后的方法的使用 1.在main.js文件里引用之前写好的文件,我的命名为htt ...
- 一天搞定jQuery(三)——使用jQuery完成复选框的全选和全不选
还记得之前我使用JavaScript来实现复选框的全选和全不选效果吗?如果读者初次翻阅本文,可记得看看教你一天玩转JavaScript(七)——使用JavaScript完成复选框的全选和全不选的效果! ...
- ThinkPHP---rbac权限管理
[一]概论 (1)简介 rbac(role based access controal),全称基于用户组/角色的权限控制. (2)概况 目前来说,一般项目有两种权限管理方式①传统方式:②rbac方式. ...
- 01JavaScript使用
JavaScript使用 1.内容写入 HTML <P onmouseover="alert('欢迎您学习JavaScript!')">鼠标移过来</P> ...
- Leetcode724:寻找数组的中心索引(java、python3)
寻找数组的中心索引 给定一个整数类型的数组 nums,请编写一个能够返回数组"中心索引"的方法. 我们是这样定义数组中心索引的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相 ...
- __cdecl、__stdcall、__fastcall 与 __pascal 浅析
call 指令与 retn 指令 首先我们得了解 CALL 和 RETN 指令的作用,才能更好地理解调用规则,这也是先决条件. 实际上,CALL 指令就是先将下一条指令的 EIP 压栈,然后 JMP ...
- 服务器的部署与Web项目的发布
今天给老师的服务器部署项目,这次是第二次,基于第一次的经验,这次可以说是驾轻就熟. 服务器的系统是Windows Server 2008 R2 (64位) 需要安装的软件是:jdk7.TomCat7. ...