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之间,所以我们可以建一个基 ...
随机推荐
- jquery实现记住用户名和密码
这里我们选择的方法是cookie的方式去记录 首先我们写将用户名和密码写到cookie的js代码 //保存到cookie function save_cookies(){ if($("#re ...
- 测试一体机ASM failgroup的相关问题处理
环境:3台虚拟机 RHEL 7.3 + Oracle RAC 11.2.0.4 问题现象:RAC运行正常,ASM磁盘组Normal冗余,有failgroup整体故障,有failgroup配置错误. 温 ...
- gitlab 源码安装=》rpm安装横向迁移(version 9.0)
准备: 下载版本地址: https://packages.gitlab.com/gitlab/gitlab-ce 迁移环境: 源码安装的gitlab9.0.13 目标迁移至9.0.13 RPM安装的环 ...
- python爬虫-基础入门-爬取整个网站《1》
python爬虫-基础入门-爬取整个网站<1> 描述: 使用环境:python2.7.15 ,开发工具:pycharm,现爬取一个网站页面(http://www.baidu.com)所有数 ...
- MyBatis基础入门《六》Like模糊查询
MyBatis基础入门<六>Like模糊查询 描述: 未改动的文件,不再粘贴出来.项目中SQL的xml映射文件重要标签如下: mapper namespace cache 配置给定命令空间 ...
- 图片和base64互转
最近项目需要将图片以base64编码,这里记录下相关的一些东西. 需要导入两个类:sun.misc.BASE64Encoder sun.misc.BASE64Decoder 下面是相关java代码: ...
- executing in nfs will not generate core dump file
最近遇到了一个奇怪的问题. linux系统的pc搭建nfs server,开发板作为nfs client,开发板中全程root权限操作,执行的程序放到 nfs server 中 exports 出的目 ...
- Sitecore标准模板字段
在Sitecore中,数据模板定义数据类型.数据模板可以包含任意数量的节,其中每个节可视地分组一些字段.Sitecore标准模板为大多数其他数据模板定义了基本模板./ sitecore / templ ...
- uvalive 3887 Slim Span
题意: 一棵生成树的苗条度被定义为最长边与最小边的差. 给出一个图,求其中生成树的最小苗条度. 思路: 最开始想用二分,始终想不到二分终止的条件,所以尝试暴力枚举最小边的长度,然后就AC了. 粗略估计 ...
- CS131&Cousera图像处理学习笔记 - L4&W2滤波和卷积
cs131: http://vision.stanford.edu/teaching/cs131_fall1617/ coursera: https://www.coursera.org/learn/ ...