#6284. 数列分块入门 8 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2   题目描述 给出一个长为 nn 的数列,以及 nn 个操作,操作涉及区间询问等于一个数 cc 的元素,并将这个区间的所有元素改为 cc. 输入格式 第一行输入一个数字 nn. 第二行输入 nn 个数字,第 i 个数字为 a_iai​,以空格隔开. 接下来输入 nn 行询问,每行输入三个数字 ll.rr.cc,以空格…
题目链接:https://loj.ac/problem/6284 题目大意:中文题目 具体思路:还是和sqrt那个题的思路相同的,标记每一块的值是不是相同的,注意lazy下标的下放. AC代码: #include<bits/stdc++.h> using namespace std; # define ll long long ; const int inf = 0x3f3f3f3f; ; ll l[maxn],r[maxn],belong[maxn]; ll flag[maxn],a[max…
题目链接 \(Description\) 给出一个长为n的数列,以及n个操作,操作涉及区间询问等于一个数c的元素,并将这个区间的所有元素改为c. \(Solution\) 模拟一些数据可以发现,询问后一整段都会被修改,几次询问后数列可能只剩下几段不同的区间了. 那么还是暴力,每个块维护的是整个块是否仅被一种权值覆盖.查询时对于相同权值的块就可以O(1)统计:否则暴力统计并修改答案:不完整的块暴力. 这样看似最差情况下每次需要O(n)的时间,但实际远远到不了 假设初始序列都是同一个值,那么查询需要…
题目链接:https://loj.ac/problem/6278 题目大意:中文题目 具体思路:数列分块模板题,对于更新的时候,我们通过一个辅助数组来进行,对于原始的数组,我们只是用来加减,然后这个辅助数组的作用就是对每一块进行排序,当查询的时候,如果不是整块的,我们直接通过a数组来记录,对于整块的,我们直接通过排序的辅助数组进行二分查找就可以了. 注意每一次更新,除了整块的,我们都需要进行对b数组这一整块的重新赋值,因为只是部分赋值的话,b数组已经排序了,这样的话数组的下标对应的数就已经改变了…
题目链接:https://loj.ac/problem/6279 题目大意:中文题目 具体思路:按照上一个题的模板改就行了,但是注意在整块查找的时候的下标问题. AC代码: #include<bits/stdc++.h> using namespace std; # define ll long long ; ; const int inf = 0x3f3f3f3f; ll l[maxn],r[maxn],belong[maxn]; ll add[maxn],a[maxn],b[maxn];…
分块的时候开一个数组标记这个区间是不是都是一样颜色的部分,如果是的话,我后面的查询,更新部分就可以直接整块操作,对于不是不全部都一样颜色的块在具体进到快里面去暴力. 在更新的时候对边上的两个不完整的块,先暴力把这个地方的标记下推下去,然后我在给它重新标记 #include<map> #include<set> #include<ctime> #include<cmath> #include<stack> #include<queue>…
Preface 最后一题我一直觉得用莫队是最好的. 数列分块入门 7--区间乘法,区间加法,单点询问 还是很简单的吧,比起数列分块入门 7就多了个区间乘. 类似于线段树,由于乘法的优先级高于加法,因此我们先乘后加. 具体的,我们对于每一个块再额外维护一个乘法标记,每次乘法时同时更新乘法/加法标记. CODE #include<cstdio> #include<cctype> #include<cmath> #include<algorithm> using…
hzwer的讲解 一 给出一个长为 \(n\) 的数列,以及 \(n\) 个操作,操作涉及区间加法,单点查值. #include <iostream> #include <cstdio> #include <cmath> using namespace std; int n, a[50005], opt, uu, vv, ww, tag[305], blc, bel[50005]; void add(int uu, int vv, int ww){ int p=bel[…
#6285. 数列分块入门 9 内存限制:256 MiB时间限制:1500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2   题目描述 给出一个长为 nn 的数列,以及 nn 个操作,操作涉及询问区间的最小众数. 输入格式 第一行输入一个数字 nn. 第二行输入 nn 个数字,第 ii 个数字为 a_iai​,以空格隔开. 接下来输入 nn 行询问,每行输入两个数字 ll.rr,以空格隔开. 表示查询位于 [l,r][l,r] 的数字…
#6283. 数列分块入门 7 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2   题目描述 给出一个长为 nn 的数列,以及 nn 个操作,操作涉及区间乘法,区间加法,单点询问. 输入格式 第一行输入一个数字 nn. 第二行输入 nn 个数字,第 ii 个数字为 a_iai​,以空格隔开. 接下来输入 nn 行询问,每行输入四个数字 \mathrm{opt}opt.ll.rr.cc,以空格隔开…