原题链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798

线段树区间更新:

 1. 区间同同时加上一个数
2. 区间同时乘以一个数
 #include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstdio>
#define lc root<<1
#define rc root<<1|1
typedef unsigned long long ull;
const int Max_N = ;
int Mod;
struct Node {
ull sum, add, mul;
};
struct SegTree {
Node seg[Max_N << ];
inline void push_up(int root) {
seg[root].sum = (seg[lc].sum + seg[rc].sum) % Mod;
}
inline void built(int root, int l, int r) {
seg[root].add = , seg[root].mul = ;
if (l == r) {
scanf("%lld", &seg[root].sum);
seg[root].sum %= Mod;
return;
}
int mid = (l + r) >> ;
built(lc, l, mid);
built(rc, mid + , r);
push_up(root);
}
inline void push_down(int root, int len) {
if (seg[root].add != || seg[root].mul != ) {
ull &_add = seg[root].add, &_mul = seg[root].mul;
seg[lc].sum = (seg[lc].sum * _mul + (len - (len >> )) * _add) % Mod;
seg[lc].mul = (seg[lc].mul * _mul) % Mod;
seg[lc].add = (seg[lc].add * _mul + _add) % Mod;
seg[rc].sum = (seg[rc].sum * _mul + (len >> ) * _add) % Mod;
seg[rc].mul = (seg[rc].mul * _mul) % Mod;
seg[rc].add = (seg[rc].add * _mul + _add) % Mod;
_add = , _mul = ;
}
}
inline void update(int root, int l, int r, int x, int y, ull val, ull mul) {
if (x > r || y < l) return;
if (x <= l && y >= r) {
seg[root].add = (seg[root].add * mul + val) % Mod;
seg[root].mul = (seg[root].mul * mul) % Mod;
seg[root].sum = (seg[root].sum * mul + val * (r - l + )) % Mod;
return;
}
push_down(root, r - l + );
int mid = (l + r) >> ;
update(lc, l, mid, x, y, val, mul);
update(rc, mid + , r, x, y, val, mul);
push_up(root);
}
inline ull query(int root, int l, int r, int x, int y) {
if (x > r || y < l) return ;
if (x <= l && y >= r) {
return seg[root].sum;
}
push_down(root, r - l + );
ull ret = ;
int mid = (l + r) >> ;
ret += query(lc, l, mid, x, y);
ret += query(rc, mid + , r, x, y);
return ret %= Mod;
}
}seg;
int main() {
#ifdef LOCAL
freopen("in.txt", "r", stdin);
freopen("out.txt", "w+", stdout);
#endif
int n, m, a, b, c, d;
while (~scanf("%d %d", &n, &Mod)) {
seg.built(, , n);
scanf("%d", &m);
while (m--) {
scanf("%d", &a);
if ( == a) {
scanf("%d %d %d", &b, &c, &d);
seg.update(, , n, b, c, , d);
} else if ( == a) {
scanf("%d %d %d", &b, &c, &d);
seg.update(, , n, b, c, d, );
} else {
scanf("%d %d", &b, &c);
printf("%lld\n", seg.query(, , n, b, c));
}
}
}
return ;
}
 

bzoj 1798 [Ahoi2009]Seq 维护序列seq的更多相关文章

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

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

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

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

  3. bzoj 1798: [Ahoi2009]Seq 维护序列seq 线段树 区间乘法区间加法 区间求和

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeO ...

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

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

  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]Seq 维护序列seq

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798 大概就是维护两个标记的线段树模板题. 设定优先级,先乘后加(只是相对的),$push ...

  8. BZOJ1798: [Ahoi2009]Seq 维护序列seq

    传送门 写这道题是为了get一个同时传送乘法下标和加法下标的小技巧,线段树模板题.不多说. 标记名字打错无限智力-- //BZOJ 1798 //by Cydiater //2016.9.13 #in ...

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

    http://www.lydsy.com/JudgeOnline/problem.php?id=1798 之前写了个快速乘..........................20多s...... 还好 ...

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

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

随机推荐

  1. tornado框架之路二

    二.路由系统 路由系统其实就是 url 和 类 的对应关系,这里不同于其他框架,其他很多框架均是 url 对应 函数,Tornado中每个url对应的是一个类. #!/usr/bin/env pyth ...

  2. rsync拉取远程文件

    mkdir -p   /doc sshpass -p ''pwd" rsync -avz -e 'ssh -o UserKnownHostsFile=/dev/null -o StrictH ...

  3. 学习总结 初步了解HTML课程

    HTML     内容(超文本标记语言) CSS       网页美化 Javascript   脚本语言 <html>  --开始标签 <head> 网页上的控制信息 < ...

  4. android View 继承关系

    二. View  SurfaceView  GLSurfaceView   View SurfaceView GLSurfaceView 功能 显示视图,内置画布,提供图形绘制函数.触屏事件.按键事件 ...

  5. 关闭窗体后,利用StreamWriter保存控件里面的数据

    以保存DataGridView里面的数据为例: 通过窗体增加的数据,没有用数据库保存,可以使用StreamWriter将数据存在临时文件里面,再次打开窗体时写入即可. private void For ...

  6. qq 登录 cordova插件

    1.下载open-sdk.jar文件和mta_sdk_x.x.x.jar文件拷贝到libs(或lib)目录下这个链接 很容易的把环境配置好http://wiki.connect.qq.com/%E5% ...

  7. jquery selector 使用方法

    <select class="selector"></select> 1 设置value为pxx的项选中 $(".selector"). ...

  8. 百度编辑器Ueditor自动换行,添加<p>的问题

    百度编辑器Ueditor其实蛮好用的,后来使用了一段时间发现,每次打开后又保存,发现都会往内容的前后都增加一个空白的<p></p>.刚开始以后是百度编辑器的问题,找了很长时间也 ...

  9. play framework 框架安装及myeclipse 导入项目

    下载 play framework 框架. 解压你你要解压的目录 E:\play-1.2.7 相对其他的WEB框架.play的配置是相当简单的.没有那么多配置文件的搞法.上手比较快,就是相关的资料比较 ...

  10. Android:控件布局(表格布局)TableLayout

    TableLayout继承LinearLayout 实例:用表格布局实现计算机布局>>>>>>>>>>>> 有多少个TableR ...