题目

在长度为\(n(n\leq 10^5)\)的数列中,

需要满足区间加,区间下取整的操作

以及能够查询区间和以及区间最小值

除数\(d\)满足\(2\leq d\leq 10^9\)

加数\(c\)满足\(-10^4\leq c\leq 10^4\)


分析

线段树,除了区间下取整,其它都挺常规的

就说区间下取整,不满足区间可加性,那显然只能从暴力入手

如果一直分治到叶子节点,时间复杂度太高,那么要找条件去提前特判

使得时间复杂度均摊\(O(nlognlog mx)\),

其中由于加数比较小,一般常数比较小

好的,那么怎样特判,那可以转换为区间减那该多好

那希望使得\(a_j-\lfloor\frac{a_j}{d}\rfloor\)相同

只要维护区间最小值和最大值,如果带进去相同,显然这一段可以被转换为区间减

然后就完成了,注意\(C++\)中的除号是向零取整,最好直接用\(\text{cmath::floor}\)


代码

#include <cstdio>
#include <cctype>
#include <cmath>
#define rr register
using namespace std;
const int N = 100011;
typedef long long lll;
int a[N], n, Q, mn[N << 2], lazy[N << 2], mx[N << 2];
lll w[N << 2];
inline signed iut() {
rr int ans = 0, f = 1;
rr char c = getchar();
while (!isdigit(c)) f = (c == '-') ? -f : f, c = getchar();
while (isdigit(c)) ans = (ans << 3) + (ans << 1) + (c ^ 48), c = getchar();
return ans * f;
}
inline void print(lll ans) {
if (ans < 0)
ans = -ans, putchar('-');
if (ans > 9)
print(ans / 10);
putchar(ans % 10 + 48);
}
inline signed min(int a, int b) { return a < b ? a : b; }
inline signed max(int a, int b) { return a > b ? a : b; }
inline void pup(int k) {
w[k] = w[k << 1] + w[k << 1 | 1], mn[k] = min(mn[k << 1], mn[k << 1 | 1]),
mx[k] = max(mx[k << 1], mx[k << 1 | 1]);
}
inline void pdown(int k, int l, int r) {
rr int mid = (l + r) >> 1, t = lazy[k];
lazy[k] = 0;
w[k << 1] += t * (mid - l + 1), w[k << 1 | 1] += t * (r - mid), mn[k << 1] += t, mn[k << 1 | 1] += t,
mx[k << 1] += t, mx[k << 1 | 1] += t, lazy[k << 1] += t, lazy[k << 1 | 1] += t;
}
inline void build(int k, int l, int r) {
if (l == r) {
w[k] = mn[k] = mx[k] = a[l];
return;
}
rr int mid = (l + r) >> 1;
build(k << 1, l, mid);
build(k << 1 | 1, mid + 1, r);
pup(k);
}
inline void update1(int k, int l, int r, int x, int y, int z) {
if (l == x && r == y) {
w[k] += 1ll * (r - l + 1) * z, lazy[k] += z, mn[k] += z, mx[k] += z;
return;
}
if (lazy[k])
pdown(k, l, r);
rr int mid = (l + r) >> 1;
if (y <= mid)
update1(k << 1, l, mid, x, y, z);
else if (x > mid)
update1(k << 1 | 1, mid + 1, r, x, y, z);
else
update1(k << 1, l, mid, x, mid, z), update1(k << 1 | 1, mid + 1, r, mid + 1, y, z);
pup(k);
}
inline void update2(int k, int l, int r, int x, int y, int z) {
if (x <= l && r <= y) {
rr int t1 = floor(1.0 * mn[k] / z);
rr int t2 = floor(1.0 * mx[k] / z);
rr int MN = mn[k] - t1, MX = mx[k] - t2;
if (MN == MX) {
mn[k] -= MN, mx[k] -= MN, lazy[k] -= MN, w[k] -= 1ll * (r - l + 1) * MN;
return;
}
}
if (lazy[k])
pdown(k, l, r);
rr int mid = (l + r) >> 1;
if (x <= mid)
update2(k << 1, l, mid, x, y, z);
if (mid < y)
update2(k << 1 | 1, mid + 1, r, x, y, z);
pup(k);
}
inline lll query1(int k, int l, int r, int x, int y) {
if (l == x && r == y)
return w[k];
if (lazy[k])
pdown(k, l, r);
rr int mid = (l + r) >> 1;
if (y <= mid)
return query1(k << 1, l, mid, x, y);
else if (x > mid)
return query1(k << 1 | 1, mid + 1, r, x, y);
else
return query1(k << 1, l, mid, x, mid) + query1(k << 1 | 1, mid + 1, r, mid + 1, y);
}
inline signed query2(int k, int l, int r, int x, int y) {
if (l == x && r == y)
return mn[k];
if (lazy[k])
pdown(k, l, r);
rr int mid = (l + r) >> 1;
if (y <= mid)
return query2(k << 1, l, mid, x, y);
else if (x > mid)
return query2(k << 1 | 1, mid + 1, r, x, y);
else
return min(query2(k << 1, l, mid, x, mid), query2(k << 1 | 1, mid + 1, r, mid + 1, y));
}
signed main() {
n = iut();
Q = iut();
for (rr int i = 1; i <= n; ++i) a[i] = iut();
build(1, 1, n);
for (rr int i = 1; i <= Q; ++i) {
rr int z = iut(), l = iut() + 1, r = iut() + 1;
switch (z) {
case 1: {
update1(1, 1, n, l, r, iut());
break;
}
case 2: {
update2(1, 1, n, l, r, iut());
break;
}
case 3: {
print(query2(1, 1, n, l, r)), putchar(10);
break;
}
case 4: {
print(query1(1, 1, n, l, r)), putchar(10);
break;
}
}
}
return 0;
}

#线段树#LOJ 6029「雅礼集训 2017 Day1」市场的更多相关文章

  1. [LOJ 6029]「雅礼集训 2017 Day1」市场

    [LOJ 6029] 「雅礼集训 2017 Day1」市场 题意 给定一个长度为 \(n\) 的数列(从 \(0\) 开始标号), 要求执行 \(q\) 次操作, 每次操作为如下四种操作之一: 1 l ...

  2. LOJ #6029. 「雅礼集训 2017 Day1」市场 线段树维护区间除法

    题目描述 从前有一个贸易市场,在一位执政官到来之前都是非常繁荣的,自从他来了之后,发布了一系列奇怪的政令,导致贸易市场的衰落. 有 \(n\) 个商贩,从\(0 \sim n - 1\) 编号,每个商 ...

  3. loj#6029. 「雅礼集训 2017 Day1」市场(线段树)

    题意 链接 Sol 势能分析. 除法是不能打标记的,所以只能暴力递归.这里我们加一个剪枝:如果区间内最大最小值的改变量都相同的话,就变成区间减. 这样复杂度是\((n + mlogn) logV\)的 ...

  4. #6029. 「雅礼集训 2017 Day1」市场 [线段树]

    考虑到每次除法,然后加法,差距会变小,于是维护加法lazytag即可 #include <cstdio> #include <cmath> #define int long l ...

  5. [LOJ 6031]「雅礼集训 2017 Day1」字符串

    [LOJ 6031] 「雅礼集训 2017 Day1」字符串 题意 给定一个长度为 \(n\) 的字符串 \(s\), \(m\) 对 \((l_i,r_i)\), 回答 \(q\) 个询问. 每个询 ...

  6. [LOJ 6030]「雅礼集训 2017 Day1」矩阵

    [LOJ 6030] 「雅礼集训 2017 Day1」矩阵 题意 给定一个 \(n\times n\) 的 01 矩阵, 每次操作可以将一行转置后赋值给某一列, 问最少几次操作能让矩阵全为 1. 无解 ...

  7. 【loj6029】「雅礼集训 2017 Day1」市场 线段树+均摊分析

    题目描述 给出一个长度为 $n$ 的序列,支持 $m$ 次操作,操作有四种:区间加.区间下取整除.区间求最小值.区间求和. $n\le 100000$ ,每次加的数在 $[-10^4,10^4]$ 之 ...

  8. 【LOJ6029】「雅礼集训 2017 Day1」市场(线段树裸题)

    点此看题面 大致题意: 维护序列,支持区间加法,区间除法(向下取整),区间求\(min\)和区间求和. 线段树维护区间除法 区间加法.区间求\(min\)和区间求和都是线段树基本操作,因此略过不提. ...

  9. loj6029 「雅礼集训 2017 Day1」市场

    传送门:https://loj.ac/problem/6029 [题解] 考虑如果有一些近似连续的段 比如 2 2 2 3 3 3,考虑在除3意义下,变成0 0 0 1 1 1,相当于整体-2 又:区 ...

  10. 【loj6029】「雅礼集训 2017 Day1」市场&&【uoj#228】基础数据结构练习题

    题解: 这两道题加上区间取min max应该算线段树几道比较不寻常的题目 其实也是挺好理解的 对于区间/d 显然在log次后就会等于0 而我们注意到如果区间中数都相等那么就可以一起除 也就是说每个区间 ...

随机推荐

  1. [BUUCTF][WEB][极客大挑战 2019]Upload 1

    打开靶机url,看到一个页面可以上传文件 上传一个图片试一下,发现上传的路径是 http://a7661b03-4852-41de-9ea4-d48c47cb50f0.node4.buuoj.cn:8 ...

  2. sklearn学习笔记之线性回归

    AI时代扑面而来,在大众面对ChatGPT和Sora发出无数惊叹号的时候,我决定不再只当一个AI时代的API调用者,而是去学习机器学习技术本身. 刚好公司也要往人工智能方向发展的计划,于是我开始从基础 ...

  3. 常用Linux命令备查

    查找在指定日期创建的文件 2种方式: find命令: # 这种方式查找到的文件会显示路径 find -name *.log -newermt '2022-06-21 08:00:00' ! -newe ...

  4. easyexcel: The maximum length of cell contents (text) is 32,767 characters

    easyexcel The maximum length of cell contents (text) is 32,767 characters 使用easyexcel向excel中写内容出现了单元 ...

  5. vue 前端自动打开文件地址进行下载

    最近在做异步导出的功能,导出的过程中前端另外启动一个查询导出进度的线程接口.如果导出完成后,把生成的文件上传到服务器,返回给前端一个文件的下载地址:前端自动打开这个地址进行跳转下载. 有两种方式 1. ...

  6. golang中关于map的value类型定义为函数类型时(方法值)的一点点思考

    文章的内容仅仅是自己关于map的value类型定义为函数类型时的一点点思考,如有不对的地方,请不吝赐教. 学习过后才知道叫做 方法值. 1.起因 最近在看老项目代码时,看到了一段类似于下面的定义,最开 ...

  7. DataX 离线跨网场景的实施配置

    配置仅限于跨不同网情况,网络互通情况方案和配置会更简单一点 内网A:MySql数据转换成Csv { "job": { "setting": { "sp ...

  8. CTF中常见编码

    ASCII编码 ASCII HEX DEC flag{hello_ctfer} 66 6c 61 67 7b 68 65 6c 6c 6f 5f 63 74 66 65 72 7d 102 108 9 ...

  9. 摆脱鼠标系列 - 打开微信(Alt+V) - 打开双核浏览器(Alt+S) - HotkeyP

    摆脱鼠标系列 - 打开微信(Alt+V) - 打开双核浏览器(Alt+S) - HotkeyP 新定义了两个快捷键 这两个比较常用

  10. 摆脱鼠标系列 - 用git命令提交代码

    需求 最近开始改变用鼠标的习惯,之前一直是用鼠标点击vscode,点击提交 现在不用鼠标,改用命令行,命令很简单,主要是习惯的改变 实现 vscode环境 ctrl + ` 快捷键打开命令行 git ...