bzoj 4540 [HNOI 2016] 序列 - 莫队算法 - Sparse-Table - 单调栈
题目传送门
题目大意
给定一个长度为$n$的序列。询问区间$[l, r]$的所有不同的子序列的最小值的和。
这里的子序列是连续的。两个子序列不同当且仅当它们的左端点或右端点不同。
不会直接上神奇数据结构的做法。
考虑莫队。当在一段右边加入一个数后,考虑它产生的贡献。
首先找到加入后这一段的最小值,那么左端点在它的左侧的时候这个最小值做出贡献。
对于它右边到新加入的数新造成的贡献用同样的方法计算,期望下多带个$log$,然后题目没说数据随机。
考虑右边这一部分其实被算重了许多次,因为最小值右边的分段情况比较固定。因为每个"最小值"有一个固定的“恶势力”范围。这个东西可以用前缀和再加上单调栈预处理。
求最小的任务就交给st表好了。
Code
/** * bzoj * Problem#4540 * Accepted * Time: 10024ms * Memory: 34932k */ #include <algorithm> #include <iostream> #include <cstdlib> #include <cstdio> #ifndef WIN32 #define Auto "%lld" #else #define Auto "%I64d" #endif using namespace std; typedef bool boolean; ); , bzmax = ; #define pii pair<int, int> #define fi first #define sc second typedef class SparseTable { public: int n; int *ar; int log2[N]; pii bz[N][bzmax]; SparseTable() { } SparseTable(int n, int* ar):n(n) { log2[] = ; ; i <= n; i++) log2[i] = log2[i >> ] + ; ; i < n; i++) bz[i][] = min(pii(ar[i], i), pii(ar[i + ], i + )); ; j < bzmax; j++) ; i + ( << j) <= n + ; i++) bz[i][j] = min(bz[i][j - ], bz[i + ( << (j - ))][j - ]); } int query(int l, int r) { if (l == r) return l; int l2 = log2[r - l]; << l2)][l2]).sc; } }SparseTable; ; #define ll long long typedef class Query { public: int l, r, id; ll res; Query() { } boolean operator < (Query b) const { if (l / cs != b.l / cs) return l / cs < b.l / cs; return r < b.r; } }Query; int n, m; ; Query *qs; SparseTable st; ll *pl, *pr; int *ar; pii *sta; inline void init() { scanf("%d%d", &n, &m); pl = )]; pr = )]; ar = )]; sta = )]; qs = )]; ; i <= n; i++) scanf("%d", ar + i); st = SparseTable(n, ar); ; i <= m; i++) scanf("%d%d", &qs[i].l, &qs[i].r), qs[i].id = i; } inline void prepare() { sta[++tp] = pii(, -inf); pl[] = , pr[n + ] = ; ; i <= n; i++) { while (tp && sta[tp].sc >= ar[i]) tp--; pl[i] = pl[sta[tp].fi] + (i - sta[tp].fi) * 1ll * ar[i]; sta[++tp] = pii(i, ar[i]); } sta[tp = ] = pii(n + , -inf); for (int i = n; i; i--) { while (tp && sta[tp].sc >= ar[i]) tp--; pr[i] = pr[sta[tp].fi] + (sta[tp].fi - i) * 1ll * ar[i]; sta[++tp] = pii(i, ar[i]); } } ll res = ; inline void solve() { sort(qs + , qs + m + ); ; , p; sid <= n / cs && c <= m; sid++) { , mdzzr = ; res = ; for ( ; c <= m && qs[c].l / cs == sid; c++) { while (mdzzr < qs[c].r) { p = st.query(mdzzl, ++mdzzr); res += (p - mdzzl + ) * 1ll * ar[p] + pl[mdzzr] - pl[p]; } while (mdzzl < qs[c].l) { p = st.query(mdzzl, mdzzr); res -= (mdzzr - p + ) * 1ll * ar[p] + pr[mdzzl] - pr[p]; mdzzl++; } while (mdzzl > qs[c].l) { p = st.query(--mdzzl, mdzzr); res += (mdzzr - p + ) * 1ll * ar[p] + pr[mdzzl] - pr[p]; } qs[c].res = res; } } ; i <= m; i++) while (qs[i].id != i) swap(qs[i], qs[qs[i].id]); ; i <= m; i++) printf(Auto"\n", qs[i].res); } int main() { init(); prepare(); solve(); ; }
bzoj 4540 [HNOI 2016] 序列 - 莫队算法 - Sparse-Table - 单调栈的更多相关文章
- BZOJ 3809 Gty的二逼妹子序列 莫队算法+分块
Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题. 对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b]的妹子的美丽度的种类数. 为了方便,我们 ...
- BZOJ 3236 AHOI 2013 作业 莫队算法
题目大意:给出一些数,问在一个区间中不同的数值有多少种,和在一个区间中不同的数值有多少个. 思路:因为没有改动,所以就想到了莫队算法.然后我写了5K+的曼哈顿距离最小生成树,然后果断T了.(100s的 ...
- BZOJ 3289: Mato的文件管理[莫队算法 树状数组]
3289: Mato的文件管理 Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 2399 Solved: 988[Submit][Status][Di ...
- [bzoj4540][Hnoi2016][序列] (莫队算法+单调栈+st表)
Description 给定长度为n的序列:a1,a2,…,an,记为a[1:n].类似地,a[l:r](1≤l≤r≤N)是指序列:al,al+1,…,ar-1,ar.若1≤l≤s≤t≤r≤n,则称a ...
- 【BZOJ4540】[Hnoi2016]序列 莫队算法+单调栈
[BZOJ4540][Hnoi2016]序列 Description 给定长度为n的序列:a1,a2,…,an,记为a[1:n].类似地,a[l:r](1≤l≤r≤N)是指序列:al,al+1,…,a ...
- bzoj 5301: [Cqoi2018]异或序列 (莫队算法)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=5301 题面; 5301: [Cqoi2018]异或序列 Time Limit: 10 Sec ...
- bzoj 3757 苹果树(树上莫队算法)
[题意] 有若干个询问,询问路径u,v上的颜色总数,另外有要求a,b,意为将a颜色看作b颜色. [思路] vfk真是神系列233. Quote: 用S(v, u)代表 v到u的路径上的结点的集合. 用 ...
- BZOJ 4540 [Hnoi2016]序列 (单调栈 + ST表 + 莫队算法)
题目链接 BZOJ4540 考虑莫队算法. 这题难在$[l, r]$到$[l, r+1]$的转移. 根据莫队算法的原理,这个时候答案应该加上 $cal(l, r+1) + cal(l+1, r+1) ...
- bzoj 3809 Gty的二逼妹子序列(莫队算法,块状链表)
[题意] 回答若干个询问,(l,r,a,b):区间[l,r]内权值在[a,b]的数有多少[种]. [思路] 考虑使用块状链表实现莫队算法中的插入与删除. 因为权值处于1..n之间,所以我们可以建一个基 ...
随机推荐
- 关于如何利用计算属性进行button的控制
element分页没用它的 (这个只要上一页下一页),比如共2页的时候,你在第一页,你肯定可以点击下一页,当你进入到第二页的时候这个button肯定就不能点击了啊,它的属性diaabled=true让 ...
- SQLServer 里面的 DDL,DML,DCL,TCL(转)
1.DDL (Data Definition Language )数据库定义语言 statements are used to define the database structure or sch ...
- 例子:动能并不是特别强(2-3)后,下M5的同时,也是恢复期到期的前一天
动能并不是特别强(2-3)后,下M5的同时,但是恢复期到期 EG.002195 2017/06/23-->2017/06/29
- maven pom文件报错:Multiple annotations found at this line 解决方案(转)
研究maven多模块项目时,因为家里和公司不能同时开发,所以把家里搭建好的项目复制到公司继续研究, 当时家里的电脑搭建好项目之后是没问题的,但是复制到公司的eclipse上之后就看到pom文件出现下面 ...
- HDU 3306 Another kind of Fibonacci(矩阵+ll超时必须用int&输入必须取模&M必须是int类型)
Another kind of Fibonacci [题目链接]Another kind of Fibonacci [题目类型]矩阵+ll超时必须用int&输入必须取模&M必须是int ...
- 从0开始搭建vue+webpack脚手架(三)
在从0开始搭建vue+webpack脚手架(二)中已经基本完成了开发环境的配置.当开发完成后,我们需要将完成的项目进行打包,接下来对打包做一些优化: 运行 $ npm run build 可生成dis ...
- java virtual machine launcher Error:Could not create the Java Virtual Machine. Error:A Fatal exception has occurred,Program will exit.
Error:Could not create the Java Virtual Machine. Error:A Fatal exception has occurred,Program will e ...
- 编写python的程序
执行python程序有两种方式: 1.交互式环境:输入代码立即执行 优点:调试程序方便 缺点:无法永久保存程序 2.代码写入文件 ...
- Spark学习之路 (四)Spark的广播变量和累加器
一.概述 在spark程序中,当一个传递给Spark操作(例如map和reduce)的函数在远程节点上面运行时,Spark操作实际上操作的是这个函数所用变量的一个独立副本.这些变量会被复制到每台机器上 ...
- 【impala学习之二】impala 使用
环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk8 CM5.4 一.Impala shell 1.进入impal ...