LOJ#6283. 数列分块入门 7
对于每个区间先乘在加,如果我修改的是部分的块,我就需要把现这个块的add和mul标记全部放下去,然后再更新。
#include<map>
#include<set>
#include<ctime>
#include<cmath>
#include<stack>
#include<queue>
#include<string>
#include<vector>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define first fi
#define second se
#define lowbit(x) (x & (-x)) typedef unsigned long long int ull;
typedef long long int ll;
const double pi = 4.0*atan(1.0);
const int inf = 0x3f3f3f3f;
const int maxn = ;
const int maxm = ;
const int mod = ;
using namespace std; int n, m, tol, T;
int block;
int a[maxn];
int add[maxn];
int mul[maxn];
int belong[maxn]; void init() {
memset(a, , sizeof a);
memset(add, , sizeof add);
memset(mul, , sizeof mul);
memset(belong, , sizeof belong);
} int L(int x) {
return (x-)*block + ;
} int R(int x) {
return min(n, x*block);
} void update1(int l, int r, int c) {
for(int i=L(belong[l]); i<=R(belong[l]); i++) {
a[i] = a[i] * mul[belong[i]] % mod + add[belong[i]];
a[i] %= mod;
}
add[belong[l]] = ;
mul[belong[l]] = ;
for(int i=l; i<=min(r, R(belong[l])); i++) {
a[i] += c;
a[i] %= mod;
}
if(belong[l] == belong[r]) return ;
if(belong[l] != belong[r]) {
for(int i=L(belong[r]); i<=R(belong[r]); i++) {
a[i] = a[i] * mul[belong[i]] % mod + add[belong[i]];
a[i] %= mod;
}
add[belong[r]] = ;
mul[belong[r]] = ;
for(int i=L(belong[r]); i<=r; i++) {
a[i] += c;
a[i] %= mod;
}
}
for(int i=belong[l]+; i<belong[r]; i++) {
add[i] += c;
add[i] %= mod;
}
} void update2(int l, int r, int c) {
for(int i=L(belong[l]); i<=R(belong[l]); i++) {
a[i] = a[i] * mul[belong[i]] % mod + add[belong[i]];
a[i] %= mod;
}
add[belong[l]] = ;
mul[belong[l]] = ;
for(int i=l; i<=min(r, R(belong[l])); i++) {
a[i] *= c;
a[i] %= mod;
}
if(belong[l] == belong[r]) return ;
if(belong[l] != belong[r]) {
for(int i=L(belong[r]); i<=R(belong[r]); i++) {
a[i] = a[i] * mul[belong[i]] % mod + add[belong[i]];
a[i] %= mod;
}
add[belong[r]] = ;
mul[belong[r]] = ;
for(int i=L(belong[r]); i<=r; i++) {
a[i] *= c;
a[i] %= mod;
}
}
for(int i=belong[l]+; i<belong[r]; i++) {
add[i] *= c;
mul[i] *= c;
add[i] %= mod;
mul[i] %= mod;
}
} int main() {
while(~scanf("%d", &n)) {
init();
block = sqrt(n);
for(int i=; i<=n; i++) {
scanf("%d", &a[i]);
belong[i] = (i-) / block + ;
mul[i] = ;
}
m = n;
while(m--) {
int op, l, r, c;
scanf("%d%d%d%d", &op, &l, &r, &c);
if(op == ) {
update1(l, r, c%mod);
} else if(op == ) {
update2(l, r, c%mod);
} else {
int ans = a[r]*mul[belong[r]]%mod + add[belong[r]]%mod;
printf("%d\n", ans%mod);
}
// for(int i=1; i<=n; i++) printf("%d%c", a[i]*mul[belong[i]]%mod + add[belong[i]]%mod, i==n ? '\n' : ' ');
}
}
return ;
}
LOJ#6283. 数列分块入门 7的更多相关文章
- LOJ #6283. 数列分块入门 7-分块(区间乘法、区间加法、单点查询)
#6283. 数列分块入门 7 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2 题目描述 给出 ...
- LOJ——#6277. 数列分块入门 1
~~推荐播客~~ 「分块」数列分块入门1 – 9 by hzwer 浅谈基础根号算法——分块 博主蒟蒻,有缘人可直接观摩以上大佬的博客... #6277. 数列分块入门 1 题目大意: 给出一个长为 ...
- LOJ #6285. 数列分块入门 9-分块(查询区间的最小众数)
#6285. 数列分块入门 9 内存限制:256 MiB时间限制:1500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2 题目描述 给 ...
- LOJ #6284. 数列分块入门 8-分块(区间查询等于一个数c的元素,并将这个区间的所有元素改为c)
#6284. 数列分块入门 8 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2 题目描述 给出 ...
- LOJ #6282. 数列分块入门 6-分块(单点插入、单点查询、数据随机生成)
#6282. 数列分块入门 6 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 1 题目描述 给出 ...
- LOJ #6281. 数列分块入门 5-分块(区间开方、区间求和)
#6281. 数列分块入门 5 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 5 题目描述 给出 ...
- LOJ #6280. 数列分块入门 4-分块(区间加法、区间求和)
#6280. 数列分块入门 4 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 题目描述 给出一个 ...
- LOJ #6279. 数列分块入门 3-分块(区间加法、查询区间内小于某个值x的前驱(比其小的最大元素))
#6279. 数列分块入门 3 内存限制:256 MiB时间限制:1500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 3 题目描述 给 ...
- LOJ #6278. 数列分块入门 2-分块(区间加法、查询区间内小于某个值x的元素个数)
#6278. 数列分块入门 2 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 6 题目描述 给出 ...
随机推荐
- C\C++学习笔记 3
C++记录7 函数指针: 函数名为地址, 地址指的是在机器指令存储的地址. double func(int line){ reture line*3.5;} void f(int line, doub ...
- oracle事务的四个特性(ACID)
事务产生的背景 当在PL/SQL中同时操作多个SQL语句,比如通过DML语句添加.修改或删除数据时,如何确保数据库数据不会因为意外而倒置错误数据是一个非常重要的问题. 以仓库发料系统为例,如果某一张领 ...
- Django的分页和中间件
一.分页 Django的分页器(paginator) view.py from django.shortcuts import render,HttpResponse # Create your vi ...
- kprobe原理解析
参考 http://www.cnblogs.com/honpey/p/4575928.html kprobe是linux内核的一个重要特性,是一个轻量级的内核调试工具,同时它又是其他一些更高级的内核 ...
- sonar结合jenkins
一.下载jenkins插件 二.系统设置 三.获取token值 4.调整 Jenkins 构建设置
- 老男孩python学习自修第二十三天【多线程】
1. 线程的创建与运行 #!/usr/bin/env python # _*_ coding:UTF-8 _*_ from threading import Thread def foo(param1 ...
- django celery redis 定时任务
0.目的 在开发项目中,经常有一些操作时间比较长(生产环境中超过了nginx的timeout时间),或者是间隔一段时间就要执行的任务. 在这种情况下,使用celery就是一个很好的选择. cele ...
- Windows上安装 TensorFlow及简单命令
1.官网及帮助文档 官网: https://www.tensorflow.org/install/install_windows 中文帮助文档:https://efeiefei.gitbooks.io ...
- Software License Manager
slmgr -ilc lenovo.xrm-ms slmgr -ipk lenovo-lenovo-lenovo-lenovo-lenovo
- 13.kubernetes之pv,pvc,configmap(带补充实例)
管理存储是管理计算的一个明显问题.该PersistentVolume子系统为用户和管理员提供了一个API,用于抽象如何根据消费方式提供存储的详细信息.为此,我们引入了两个新的API资源:Persist ...