1798: [Ahoi2009]Seq 维护序列seq

Time Limit: 1 Sec  Memory Limit: 256 MB

题目连接

http://www.lydsy.com/JudgeOnline/problem.php?id=1798

Description

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

Input

第一行两个整数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)。 同一行相邻两数之间用一个空格隔开,每行开头和末尾没有多余空格。

Output

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

Sample Input

7 43

1 2 3 4 5 6 7

5

1 2 5 5

3 2 4

2 3 7 9

3 1 3

3 4 7

Sample Output

2

35

8

HINT

 

题意

题解:

啊,就是一个傻逼线段树,区间乘法+区间加法,都扔给一个updata就好,然后最后搞一搞

代码:

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <cmath>
  4. #include <string>
  5. #include <iostream>
  6. #include <algorithm>
  7. #include <queue>
  8. #include <set>
  9. #include <map>
  10. using namespace std;
  11. typedef long long ll;
  12. #define rep(i, n) for(int i=0; i<(n); ++i)
  13. #define for1(i,a,n) for(int i=(a);i<=(n);++i)
  14. #define for2(i,a,n) for(int i=(a);i<(n);++i)
  15. #define for3(i,a,n) for(int i=(a);i>=(n);--i)
  16. #define for4(i,a,n) for(int i=(a);i>(n);--i)
  17. #define CC(i,a) memset(i,a,sizeof(i))
  18. #define read(a) a=getint()
  19. #define print(a) printf("%d", a)
  20. #define dbg(x) cout << (#x) << " = " << (x) << endl
  21. #define error(x) (!(x)?puts("error"):0)
  22. #define rdm(x, i) for(int i=ihead[x]; i; i=e[i].next)
  23. inline const int getint() { int r=, k=; char c=getchar(); for(; c<''||c>''; c=getchar()) if(c=='-') k=-; for(; c>=''&&c<=''; c=getchar()) r=r*+c-''; return k*r; }
  24.  
  25. const int N=;
  26. #define lc x<<1
  27. #define rc x<<1|1
  28. #define MID (l+r)>>1
  29. #define lson l, mid, lc
  30. #define rson mid+1, r, rc
  31.  
  32. int n, MD;
  33.  
  34. struct node {
  35. int sum, add, mul;
  36. void upd(int a, int m, int len) {
  37. add=((ll)add*m+a)%MD;
  38. mul=((ll)mul*m)%MD;
  39. sum=((ll)sum*m+(ll)a*len)%MD;
  40. }
  41. }t[N<<];
  42. void pushdown(int x, int len) {
  43. if(t[x].add!= || t[x].mul!=)
  44. t[lc].upd(t[x].add, t[x].mul, (len-(len>>))),
  45. t[rc].upd(t[x].add, t[x].mul, len>>),
  46. t[x].add=, t[x].mul=;
  47. }
  48. void pushup(int x) { t[x].sum=(t[lc].sum+t[rc].sum)%MD; }
  49. void build(int l, int r, int x) {
  50. t[x].add=;
  51. t[x].mul=;
  52. if(l==r) { t[x].sum=getint(); return; }
  53. int mid=MID;
  54. build(lson); build(rson);
  55. pushup(x);
  56. }
  57. void update(int l, int r, int x, int L, int R, int add, int mul) {
  58. if(L<=l && r<=R) { t[x].upd(add, mul, r-l+); return; }
  59. pushdown(x, r-l+);
  60. int mid=MID;
  61. if(L<=mid) update(lson, L, R, add, mul);
  62. if(mid<R) update(rson, L, R, add, mul);
  63. pushup(x);
  64. }
  65. int query(int l, int r, int x, int L, int R) {
  66. if(L<=l && r<=R) return t[x].sum;
  67. pushdown(x, r-l+);
  68. int mid=MID, ret=;
  69. if(L<=mid) ret+=query(lson, L, R);
  70. if(mid<R) ret+=query(rson, L, R);
  71. ret%=MD;
  72. return ret;
  73. }
  74. int main() {
  75. read(n); read(MD);
  76. build(, n, );
  77. int m=getint();
  78. while(m--) {
  79. int c=getint();
  80. if(c==) { int l=getint(), r=getint(), x=getint(); update(, n, , l, r, , x); }
  81. else if(c==) { int l=getint(), r=getint(), x=getint(); update(, n, , l, r, x, ); }
  82. else if(c==) { int l=getint(), r=getint(); printf("%d\n", query(, n, , l, r)); }
  83. }
  84. return ;
  85. }
  1. #include <cstdio>
  2. #include <cstring>
  3. #include <cmath>
  4. #include <string>
  5. #include <iostream>
  6. #include <algorithm>
  7. #include <queue>
  8. #include <set>
  9. #include <map>
  10. using namespace std;
  11. typedef long long ll;
  12. #define rep(i, n) for(int i=0; i<(n); ++i)
  13. #define for1(i,a,n) for(int i=(a);i<=(n);++i)
  14. #define for2(i,a,n) for(int i=(a);i<(n);++i)
  15. #define for3(i,a,n) for(int i=(a);i>=(n);--i)
  16. #define for4(i,a,n) for(int i=(a);i>(n);--i)
  17. #define CC(i,a) memset(i,a,sizeof(i))
  18. #define read(a) a=getint()
  19. #define print(a) printf("%d", a)
  20. #define dbg(x) cout << (#x) << " = " << (x) << endl
  21. #define error(x) (!(x)?puts("error"):0)
  22. #define rdm(x, i) for(int i=ihead[x]; i; i=e[i].next)
  23. inline const int getint() { int r=, k=; char c=getchar(); for(; c<''||c>''; c=getchar()) if(c=='-') k=-; for(; c>=''&&c<=''; c=getchar()) r=r*+c-''; return k*r; }
  24.  
  25. const int N=;
  26. #define lc x<<1
  27. #define rc x<<1|1
  28. #define MID (l+r)>>1
  29. #define lson l, mid, lc
  30. #define rson mid+1, r, rc
  31.  
  32. int n, MD;
  33.  
  34. struct node {
  35. int sum, add, mul;
  36. void upd(int a, int m, int len) {
  37. add=((ll)add*m+a)%MD;
  38. mul=((ll)mul*m)%MD;
  39. sum=((ll)sum*m+(ll)a*len)%MD;
  40. }
  41. }t[N<<];
  42. void pushdown(int x, int len) {
  43. if(t[x].add!= || t[x].mul!=)
  44. t[lc].upd(t[x].add, t[x].mul, (len-(len>>))),
  45. t[rc].upd(t[x].add, t[x].mul, len>>),
  46. t[x].add=, t[x].mul=;
  47. }
  48. void pushup(int x) { t[x].sum=(t[lc].sum+t[rc].sum)%MD; }
  49. void build(int l, int r, int x) {
  50. t[x].add=;
  51. t[x].mul=;
  52. if(l==r) { t[x].sum=getint(); return; }
  53. int mid=MID;
  54. build(lson); build(rson);
  55. pushup(x);
  56. }
  57. void update(int l, int r, int x, int L, int R, int add, int mul) {
  58. if(L<=l && r<=R) { t[x].upd(add, mul, r-l+); return; }
  59. pushdown(x, r-l+);
  60. int mid=MID;
  61. if(L<=mid) update(lson, L, R, add, mul);
  62. if(mid<R) update(rson, L, R, add, mul);
  63. pushup(x);
  64. }
  65. int query(int l, int r, int x, int L, int R) {
  66. if(L<=l && r<=R) return t[x].sum;
  67. pushdown(x, r-l+);
  68. int mid=MID, ret=;
  69. if(L<=mid) ret+=query(lson, L, R);
  70. if(mid<R) ret+=query(rson, L, R);
  71. ret%=MD;
  72. return ret;
  73. }
  74. int main() {
  75. read(n); read(MD);
  76. build(, n, );
  77. int m=getint();
  78. while(m--) {
  79. int c=getint();
  80. if(c==) { int l=getint(), r=getint(), x=getint(); update(, n, , l, r, , x); }
  81. else if(c==) { int l=getint(), r=getint(), x=getint(); update(, n, , l, r, x, ); }
  82. else if(c==) { int l=getint(), r=getint(); printf("%d\n", query(, n, , l, r)); }
  83. }
  84. return ;
  85. }

bzoj 1798: [Ahoi2009]Seq 维护序列seq 线段树 区间乘法区间加法 区间求和的更多相关文章

  1. 【BZOJ1798】【AHOI2009】维护序列(线段树)

    题目链接 题解 这不就是luogu的线段树2的板子吗.... 没有任何的区别... 上代码吧... #include<iostream> #include<cstdio> #i ...

  2. BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )

    线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...

  3. Bzoj 1798: [Ahoi2009]Seq 维护序列seq(线段树区间操作)

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小可 ...

  4. bzoj 1798: [Ahoi2009]Seq 维护序列seq (线段树 ,多重标记下放)

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

  5. 1798: [Ahoi2009]Seq 维护序列seq

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

  6. BZOJ1798: [Ahoi2009]Seq 维护序列seq[线段树]

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

  7. BZOJ_1798_[AHOI2009]维护序列_线段树

    BZOJ_1798_[AHOI2009]维护序列_线段树 题意:老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: ( ...

  8. [AHOI 2009] 维护序列(线段树模板题)

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小 ...

  9. bzoj 1798 [Ahoi2009]Seq 维护序列seq(线段树+传标)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1798 [题意] 给定一个序列,要求提供区间乘/加,以及区间求和的操作 [思路] 线段树 ...

随机推荐

  1. linux调试工具glibc的演示分析

    偶然中发现,下面的两端代码表现不一样 void main(){ void* p1 = malloc(32);       free(p1); free(p1); // 这里会报double free ...

  2. httpd功能配置之虚拟主机【转】

    apache默认使用80端口提供服务,使用主服务器配置的话,一台物理机只能提供一个站点服务:可以使用虚拟主机方式提供不同的访问,以实现一台主机提供多站点服务. 虚拟主机的实现方式有三种:基于端口.基于 ...

  3. Nginx中worker_connections的问题

    查看日志,有一个[warn]: 3660#0: 20000 worker_connections are more than open file resource limit: 1024 !! 原来安 ...

  4. python 根据输入的内容输出类型

    类型判断 from functools import singledispatch import numbers from collections import abc from collection ...

  5. 十九、springboot使用@ControllerAdvice(二)之深入理解

    前言: 接口类项目开发时,为了便于后期查找问题,一般会拦截器或过滤器中记录每个接口请求的参数与响应值记录, 请求参数很容易从request中获取,但controller的返回值无法从response中 ...

  6. 洛谷P2194HXY烧情侣

    传送门啦 这个题可以说是tarjan强连通分量的裸题,但需要维护每个强连通分量的最小值,所以做法就很明确了. 我们先明确几个数组的意思: 1.首先是tarjan缩点中的几个数组: dfn[i]:i点的 ...

  7. .gitignore文件如何编写?

    .gitignore文件即 项目中不需要被追踪(track)且上传到git系统的文件 <1>忽略文件的原则 a.忽略操作系统自动生成的文件,比如缩略图等 b.忽略编译生成的中间文件.可执行 ...

  8. LoadRunner中文乱码问题解决方法

    LoadRunner中文乱码问题解决方法 前段时间在录制,增强,整合LoadRunner脚本,期间两次遇到了中文乱码问题.在此记录一下中文乱码问题的解决办法. 一.录制回放中文乱码 我录制登陆的脚本, ...

  9. Docker简介与安装(一)

    Docker简介 Docker 是 Docker.Inc 公司开源的一个基于 LXC技术之上构建的Container容器引擎, 源代码托管在 GitHub 上, 基于Go语言并遵从Apache2.0协 ...

  10. 003 Scipy库简介

    参考文档补充原本的文档: https://www.cnblogs.com/mrchige/p/6504324.html 一:原本的简单介绍 1.Scipy库 Scipy库是基于python生态的一款开 ...