传送门(洛谷)

传送门(bzoj)

题目

老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成。 有长为N的数列,不妨设为a1,a2,…,aN 。有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列中的一段数全部加一个值; (3)询问数列中的一段数的和,由于答案可能很大,你只需输出这个数模P的值。

输入格式:

第一行两个整数N和P(1≤P≤1000000000)。
第二行含有N个非负整数,从左到右依次为a1,a2,…,aN, (0≤ai≤1000000000,1≤i≤N)。
第三行有一个整数M,表示操作总数。
从第四行开始每行描述一个操作,输入的操作有以下三种形式:
操作1:“1 t g c”(不含双引号)。表示把所有满足t≤i≤g的ai改为ai×c (1≤t≤g≤N,0≤c≤1000000000)。
操作2:“2 t g c”(不含双引号)。表示把所有满足t≤i≤g的ai改为ai+c (1≤t≤g≤N,0≤c≤1000000000)。
操作3:“3 t g”(不含双引号)。询问所有满足t≤i≤g的ai的和模P的值 (1≤t≤g≤N)。 同一行相邻两数之间用一个空格隔开,每行开头和末尾没有多余空格。

输出格式:

对每个操作3,按照它在输入中出现的顺序,依次输出一行一个整数表示询问结果。

分析

参见洛谷线段树模板2,lazy标记记录两个值mul和add。

代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<ctime>
#include<vector>
#include<set>
#include<map>
#include<stack>
using namespace std;
long long n,m,mod;
struct node {
long long sum,add,mul;
}d[];
inline void build(long long le,long long ri,long long pos,long long wh,long long k){
d[wh].sum+=k;
d[wh].mul=;
if(le==ri)return;
long long mid=(le+ri)>>;
if(mid>=pos)build(le,mid,pos,wh<<,k);
else build(mid+,ri,pos,(wh<<)|,k);
}
inline void udm(long long le,long long ri,long long x,long long y,long long wh,long long k){
if(le>=x&&ri<=y){
d[wh].mul=d[wh].mul*k%mod;
d[wh].add=d[wh].add*k%mod;
d[wh].sum=d[wh].sum*k%mod;
return;
}
long long mid=(le+ri)>>;
long long t=d[wh].mul,s=d[wh].add;
d[wh].mul=,d[wh].add=;
d[wh<<].mul=d[wh<<].mul*t%mod;
d[wh<<].add=(d[wh<<].add*t%mod+s)%mod;
d[wh<<].sum=(d[wh<<].sum*t%mod+(mid-le+)*s%mod)%mod;
d[(wh<<)|].mul=d[(wh<<)|].mul*t%mod;
d[(wh<<)|].add=(d[(wh<<)|].add*t%mod+s)%mod;
d[(wh<<)|].sum=(d[(wh<<)|].sum*t%mod+(ri-mid)*s%mod)%mod;
if(mid>=x)udm(le,mid,x,y,wh<<,k);
if(mid<y)udm(mid+,ri,x,y,(wh<<)|,k);
d[wh].sum=(d[wh<<].sum+d[(wh<<)|].sum)%mod;
}
inline void uda(long long le,long long ri,long long x,long long y,long long wh,long long k){
if(le>=x&&ri<=y){
d[wh].add=(d[wh].add+k)%mod;
d[wh].sum=(d[wh].sum+(ri-le+)*k%mod)%mod;
return;
}
long long mid=(le+ri)>>;
long long t=d[wh].mul,s=d[wh].add;
d[wh].mul=,d[wh].add=;
d[wh<<].mul=d[wh<<].mul*t%mod;
d[wh<<].add=(d[wh<<].add*t%mod+s)%mod;
d[wh<<].sum=(d[wh<<].sum*t%mod+(mid-le+)*s%mod)%mod;
d[(wh<<)|].mul=d[(wh<<)|].mul*t%mod;
d[(wh<<)|].add=(d[(wh<<)|].add*t%mod+s)%mod;
d[(wh<<)|].sum=(d[(wh<<)|].sum*t%mod+(ri-mid)*s%mod)%mod;
if(mid>=x)uda(le,mid,x,y,wh<<,k);
if(mid<y)uda(mid+,ri,x,y,(wh<<)|,k);
d[wh].sum=(d[wh<<].sum+d[(wh<<)|].sum)%mod;
}
inline long long que(long long le,long long ri,long long x,long long y,long long wh){
if(le>=x&&ri<=y)return d[wh].sum%mod;
long long mid=(le+ri)>>,ans=;
long long t=d[wh].mul,s=d[wh].add;
d[wh].mul=,d[wh].add=;
d[wh<<].mul=d[wh<<].mul*t%mod;
d[wh<<].add=(d[wh<<].add*t%mod+s)%mod;
d[wh<<].sum=(d[wh<<].sum*t%mod+(mid-le+)*s%mod)%mod;
d[(wh<<)|].mul=d[(wh<<)|].mul*t%mod;
d[(wh<<)|].add=(d[(wh<<)|].add*t%mod+s)%mod;
d[(wh<<)|].sum=(d[(wh<<)|].sum*t%mod+(ri-mid)*s%mod)%mod;
if(mid>=x)ans=(ans+que(le,mid,x,y,wh<<))%mod;
if(mid<y)ans=(ans+que(mid+,ri,x,y,(wh<<)|))%mod;
d[wh].sum=(d[wh<<].sum+d[(wh<<)|].sum)%mod;
return ans;
}
int main()
{ long long i,j,k,x,y,z;
scanf("%lld%lld",&n,&mod);
for(i=;i<=n;i++){
scanf("%lld",&x);
build(,n,i,,x);
}
scanf("%lld",&m);
for(i=;i<=m;i++){
scanf("%lld",&k);
if(k==){
scanf("%lld%lld%lld",&x,&y,&z);
udm(,n,x,y,,z);
}else if(k==){
scanf("%lld%lld%lld",&x,&y,&z);
uda(,n,x,y,,z);
}else {
scanf("%lld%lld",&x,&y);
printf("%lld\n",que(,n,x,y,));
}
}
return ;
}

p2023&bzoj1798 维护序列的更多相关文章

  1. 洛谷 P2023 [AHOI2009]维护序列

    P2023 [AHOI2009]维护序列 题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中 ...

  2. 洛谷 P2023 [AHOI2009]维护序列 题解

    P2023 [AHOI2009]维护序列 题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中 ...

  3. 洛谷P2023 [AHOI2009]维护序列(线段树区间更新,区间查询)

    洛谷P2023 [AHOI2009]维护序列 区间修改 当我们要修改一个区间时,要保证 \(ax+b\) 的形式,即先乘后加的形式.当将区间乘以一个数 \(k\) 时,原来的区间和为 \(ax+b\) ...

  4. 洛谷P3373 【模板】线段树 2 && P2023 [AHOI2009]维护序列——题解

    题目传送: P3373 [模板]线段树 2  P2023 [AHOI2009]维护序列 该题较传统线段树模板相比多了一个区间乘的操作.一提到线段树的区间维护问题,就自然想到了“懒标记”:为了降低时间复 ...

  5. P2023 [AHOI2009]维护序列 题解(线段树)

    题目链接 P2023 [AHOI2009]维护序列 解题思路 线段树板子.不难,但是...有坑.坑有多深?一页\(WA\). 由于乘法可能乘\(k=0\),我这种做法可能会使结果产生负数.于是就有了这 ...

  6. [洛谷P2023] [AHOI2009]维护序列

    洛谷题目链接:[AHOI2009]维护序列 题目描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列 ...

  7. BZOJ1798 维护序列seq

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 8058  Solved: 2964[Submit ...

  8. 【双标记线段树】bzoj1798维护序列seq

    一.题目 描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列 ...

  9. 【题解】洛谷P2023 [AHOI2009] 维护序列(线段树)

    洛谷P2023:https://www.luogu.org/problemnew/show/P2023 思路 需要2个Lazy-Tag 一个表示加的 一个表示乘的 需要先计算乘法 再计算加法 来自你谷 ...

随机推荐

  1. P2567 [SCOI2010]幸运数字

    题目 P2567 [SCOI2010]幸运数字 做法 容斥+剪枝 先预处理幸运数字,别看数据范围这么大,其实也没几个,然后去掉倍数这种 然后处理相似数字,一眼的容斥,递归选数然后求出这些的公倍数容斥一 ...

  2. Android系统OTA升级包制作【转】

    本文转载自:http://blog.csdn.net/dingfengnupt88/article/details/52882788 Android系统升级分为整包升级和差分包升级,整包升级就是将系统 ...

  3. in型子查询陷阱,exists子查询

    in 型子查询引出的陷阱 select goods_id from goods where cat_id in (1,2,3) 直接用id,不包含子查询,不会中陷阱 题: 在ecshop商城表中,查询 ...

  4. Oracle视图的使用

    --视图的语法 create [ or replace ] [NO Force | Force] View schema.view_name--视图名称 [(alias,...)inline_cons ...

  5. dos命令行中不同磁盘的调转

    windows下,dos中不同磁盘的跳转: 直接 盘符+回车: 如跳转到d盘: D:回车即可 : Microsoft Windows [版本 10.0.10586] (c) 2015 Microsof ...

  6. java.sql.SQLException: Column count doesn't match value count at row 1 Query: insert into category values(null,?,?,?) Parameters: [1111111, 1111, 软件]

    java.sql.SQLException 问题: java.sql.SQLException: Column count doesn't match value count at row 1 Que ...

  7. codeforces 633D D. Fibonacci-ish(dfs+暴力+map)

    D. Fibonacci-ish time limit per test 3 seconds memory limit per test 512 megabytes input standard in ...

  8. Gym - 100570C: Subrect Query (巧妙的单调队列)

    De Prezer loves rectangles.He has a n × m rectangle which there is a number in each of its cells. We ...

  9. ACM学习历程—51NOD1028 大数乘法V2(FFT)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1028 题目大意就是求两个大数的乘法. 但是用普通的大数乘法,这 ...

  10. Cannot resolve class or package 'springframework' less... (Ctrl+F1) Inspection info:Spring XML mode

    其实这个问题是由于MySQL 这个jar 包依赖类型默认是runtime ,也就是说只有运行时生效,所以虽然这里报错,但是不影响你代码运行. 解决方案: 将runtime 修改为Compile 即可 ...