bzoj 1798 [Ahoi2009]Seq 维护序列seq
原题链接: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的更多相关文章
- BZOJ 1798: [Ahoi2009]Seq 维护序列seq( 线段树 )
线段树.. 打个 mul , add 的标记就好了.. 这个速度好像还挺快的...( 相比我其他代码 = = ) 好像是#35.. ---------------------------------- ...
- 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 老师交给小可可一个维护数列的任务,现在小可 ...
- 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]Seq 维护序列seq
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1798 大概就是维护两个标记的线段树模板题. 设定优先级,先乘后加(只是相对的),$push ...
- BZOJ1798: [Ahoi2009]Seq 维护序列seq
传送门 写这道题是为了get一个同时传送乘法下标和加法下标的小技巧,线段树模板题.不多说. 标记名字打错无限智力-- //BZOJ 1798 //by Cydiater //2016.9.13 #in ...
- 【BZOJ】1798: [Ahoi2009]Seq 维护序列seq(线段树)
http://www.lydsy.com/JudgeOnline/problem.php?id=1798 之前写了个快速乘..........................20多s...... 还好 ...
- bzoj 1798 [Ahoi2009]Seq 维护序列seq(线段树+传标)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1798 [题意] 给定一个序列,要求提供区间乘/加,以及区间求和的操作 [思路] 线段树 ...
随机推荐
- c语言解数独
来自:http://my.oschina.net/lovewxm/blog/288043?p=1 #include <stdio.h> #include <stdlib.h> ...
- MySQL数据库获取多个汉字拼音的首字母函数
需求简介:最近的一个项目,想实现如下图所示的显示效果.很明显,如果能够获取对应的汉字词组中每个汉字的拼音首字母就可以实现了,如果是固定的几组汉字,人为的拼一下就可以 了,不过项目中有多处功能需要这个效 ...
- 学习记录 java 哈希
哈希表(Hash Table,又叫散列表),是存储键值对(Key-value)的表,之所以不叫它Map(键值对一起存储一般叫做Map),是因为它下面的特性:它能把关键码(key)映射到表中的一个位置来 ...
- Redis 1:简介
导读:在今日开讲的项目中,用到了redis数据库.老听大家在说,我都不知道是个啥玩意儿.然后这两天在准备知识分享的事儿,我先大概了解了解,然后讲的时候,能有点共鸣.所以,本篇博客,是在自己跟读完MVA ...
- Save a bricked Samsung Note 3 and do extraction
The case scenario was about bank robery and the suspect threw his Samsung Note 3 into the river. For ...
- Android Malware Analysis
A friend of mine asked me help him to examine his Android 5.0 smartphone. He did not say what's wron ...
- State
#include <iostream> using namespace std; #define DESTROY_POINTER(ptr) if (ptr) { delete ptr; p ...
- DataGridView控件中添加ComboBox下拉列表框的实现
//ComboBox控件拖放到DataGridView控件的某个位置 //添加年龄下拉框 private void BindAge() { //我这里添加的是静态数据,一般都是从数据库读出来的,这里就 ...
- 在Array原型链上扩展remove,contain等方法所遇到的坑
相信jser兄弟们肯定会碰到这样一个问题, 在做数组类的操作的时候,会要求删除数组中的一个元素:亦或是判断某值是否存在于这个数组: OK,拿删除数组元素举例,扩展方法为: Array.prototyp ...
- js各种宽高(1)
在javascript中操作dom节点让其运动的时候,常常会涉及到各种宽高以及位置坐标等概念,如果不能很好地理解这些属性所代表的意义,就不能理解js的运动原理,同时,由于这些属性概念较多,加上浏览器之 ...