[bzoj1798][Ahoi2009]Seq 维护序列seq ([洛谷P3373]【模板】线段树 2)
题目大意:有$n$个数,有$m$个操作,有三种:
- $1\;l\;r\;x:$把区间$[l,r]$内的数乘上$x$
- $2\;l\;r\;x:$把区间$[l,r]$内的数加上$x$
- $3\;l\;r:$询问区间$[l,r]$的和,对$p$取模
(线段树2就是先读入$n\;m\;p$,再读入序列;本题是先读入$n\;p$,读入序列,再读入$m$,双倍经验)
题解:线段树,把$lazy\_tag$变成两个,分别记录区间加和区间乘,注意乘法的优先级比加法高
卡点:无(我以前写的是什么代码啊?)
C++ Code:
#include <cstdio>
#define maxn 100010 << 2
long long V[maxn], cov[maxn], tg[maxn];
int n, m;
int s[maxn], L, R;
long long p, x;
void update(int rt) {
V[rt] = (V[rt << 1] + V[rt << 1 | 1]) % p;
}
void build(int rt, int l, int r) {
cov[rt] = 1;
if (l == r) {
V[rt] = s[l] % p;
return ;
}
int mid = l + r >> 1;
build(rt << 1, l, mid);
build(rt << 1 | 1, mid + 1, r);
update(rt);
}
void pushdown(int rt, long long len) {
long long &Cov = cov[rt], &Tg = tg[rt];
V[rt << 1] = (V[rt << 1] * Cov + Tg * (len + 1 >> 1)) % p;
V[rt << 1 | 1] = (V[rt << 1 | 1] * Cov + Tg * (len >> 1)) % p;
cov[rt << 1] = (cov[rt << 1] * Cov) % p;
cov[rt << 1 | 1] = (cov[rt << 1 | 1] * Cov) % p;
tg[rt << 1] = (tg[rt << 1] * Cov + Tg) % p;
tg[rt << 1 | 1] = (tg[rt << 1 | 1] * Cov + Tg) % p;
Cov = 1, Tg = 0;
}
void add1(int rt, int l, int r) {
if (L <= l && R >= r) {
V[rt] = (V[rt] * x) % p;
cov[rt] = (cov[rt] * x) % p;
tg[rt] = (tg[rt] * x) % p;
return ;
}
int mid = l + r >> 1;
if (cov[rt] != 1 || tg[rt]) pushdown(rt, r - l + 1);
if (L <= mid) add1(rt << 1, l, mid);
if (R > mid) add1(rt << 1 | 1, mid + 1, r);
update(rt);
}
void add2(int rt, int l, int r) {
if (L <= l && R >= r) {
V[rt] = (V[rt] + x * (r - l + 1ll)) % p;
tg[rt] = (tg[rt] + x) % p;
return ;
}
int mid = l + r >> 1;
if (cov[rt] != 1 || tg[rt]) pushdown(rt, r - l + 1);
if (L <= mid) add2(rt << 1, l, mid);
if (R > mid) add2(rt << 1 | 1, mid + 1, r);
update(rt);
}
long long ask(int rt, int l, int r) {
if (L <= l && R >= r) return V[rt] % p;
int mid = l + r >> 1;
long long ans = 0;
if (cov[rt] != 1 || tg[rt]) pushdown(rt, r - l + 1);
if (L <= mid) ans = ask(rt << 1, l, mid);
if (R > mid) ans = (ans + ask(rt << 1 | 1, mid + 1, r)) % p;
return ans;
}
int main() {
scanf("%d%lld", &n, &p);
for (int i = 1; i <= n; i++) scanf("%d", s + i);
build(1, 1, n);
scanf("%d", &m);
while (m --> 0) {
long long op;
scanf("%lld%d%d", &op, &L, &R);
switch (op) {
case 1: {
scanf("%lld", &x);
add1(1, 1, n);
break;
}
case 2: {
scanf("%lld", &x);
add2(1, 1, n);
break;
}
default: printf("%lld\n", ask(1, 1, n));
}
}
return 0;
}
[bzoj1798][Ahoi2009]Seq 维护序列seq ([洛谷P3373]【模板】线段树 2)的更多相关文章
- 洛谷P3373 [模板]线段树 2(区间增减.乘 区间求和)
To 洛谷.3373 [模板]线段树2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格 ...
- 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( 线段树 )
线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...
- 1798: [Ahoi2009]Seq 维护序列seq
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 2930 Solved: 1087[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 线段树 区间乘法区间加法 区间求和
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 题解
题目大意: 有长为N的数列,有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一段数全部加一个值; (3)询问数列中的一段数的和,由于答案可能很大,你只需输出这个数模P的值. ...
- 【bzoj1798】[Ahoi2009]Seq 维护序列seq 线段树
题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一 ...
随机推荐
- 继续分享shell 之变量使用
变量类型 运行shell时,会同时存在三种变量: 1) 局部变量 局部变量在脚本或命令中定义,仅在当前shell实例中有效,其他shell启动的程序不能访问局部变量. 2) 环境变量 所有的程序,包括 ...
- Eloquent: 修改器
感觉好长时间没写东西了,一方面主要是自己的角色发生了变化,每天要面对各种各样的事情和突发事件,不能再有一个完整的长时间让自己静下来写代码,或者写文章. 另一方面现在公司技术栈不再停留在只有 Larav ...
- 日期格式兼容iOS
iOS不支持2016-02-11 12:21:12格式的日期 目前Safari可以支持的标准格式: MM-dd-yyyy yyyy/MM/dd MM/dd/yyyy MMMM dd, yyyy MMM ...
- lvs+ipvsadm负载均衡
使用LVS实现负载均衡原理及安装配置详解 负载均衡集群是 load balance 集群的简写,翻译成中文就是负载均衡集群.常用的负载均衡开源软件有nginx.lvs.haproxy,商业的硬件负载均 ...
- dts--tests(三)
sample_built.py """ DPDK Test suite. Test sample_built. """ import uti ...
- Laravel5.5.x集成Swagger (L5-Swagger) 只讲Laravel5.5.x的集成,laravel其他版本请自行研究或参考github上的说明
--------上图 截取自Github 官网上的安装参考----------------------------------------------------------------------- ...
- python——直方图均衡化
from PIL import Image from pylab import * from numpy import * def histeq(im,nbr_bins = 256): "& ...
- 中国剩余定理算法详解 + POJ 1006 Biorhythms 生理周期
转载请注明出处:http://exp-blog.com/2018/06/24/pid-1054/ #include <iostream> #include <cstdio> u ...
- poj 3111 卖珠宝问题 最大化平均值
题意:有N件分别价值v重量w的珠宝,希望保留k件使得 s=v的和/w的和最大 思路:找到贡献最大的 设当前的s为mid(x) 那么贡献就是 v-w*x 排序 ,取前k个 bool operator&l ...
- 8 Django 模型层(1)--orm简介
ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的 ...