[HNOI2016]序列(莫队,RMQ)
[HNOI2016]序列(莫队,RMQ)
一眼看不出来怎么用数据结构维护
然后还没修改
所以考虑莫队
以$(l,r-1) -> (l,r)$为例
对答案的贡献是$\Sigma_{i=l}^{r}minval(a[i:r])$
考虑维护前缀和
先用单调栈扫出$w[i]$作为最小值的左边界右边界$l_i,r_i$
然后回到上面的例子贡献就是$frontsum_{r}-frontsum_{rmqmin(l,r)}+w[rmqmin(l,r)]*(rmqmin(l,r)-l+1)$
完结...等等我好像忘了点啥
$frontsum_{i}$指的是从i向前拓展的i个包含i的子区间的区间最小值的和,也是可以用单调栈求出来的
时间复杂度略
#include<cstdio>
#include<cmath>
#include<algorithm>
using std::sort;
typedef long long lint;
const int N=100011;
template<typename tp>void read(tp &kk){
#define ak *
tp phy=0,ioi=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')ioi=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){phy=phy*10+ch-'0';ch=getchar();}
kk=phy ak ioi;
}
int n,m,bl[N];
lint w[N];
int bsize; int lg[N];
int lgl[N][17];
void is()
{
for(int i=2;i<=n;i++) lg[i]=lg[i>>1]+1;
for(int i=1;i<=n;i++) lgl[i][0]=i;
for(int k=1;k<=lg[n];k++)
{
for(int i=1;i-1+(1<<k)<=n;i++)
{
lgl[i][k]=w[lgl[i][k-1]]<w[lgl[i+(1<<(k-1))][k-1]]?lgl[i][k-1]:lgl[i+(1<<(k-1))][k-1];
}
}
}
int rmq(int l,int r){
return w[lgl[l][lg[r-l+1]]]<
w[lgl[r-(1<<lg[r-l+1])+1][lg[r-l+1]]]?
lgl[l][lg[r-l+1]]:
lgl[r-(1<<lg[r-l+1])+1][lg[r-l+1]];
} int li[N],ri[N];
int st[N],hop;
void rkk()
{
for(int i=1;i<=n;i++)
{
while(hop&&w[st[hop]]>w[i])
ri[st[hop]]=i-1,hop--;
st[++hop]=i;
if(i==n)
while(hop) ri[st[hop]]=i,hop--;
}
for(int i=n;i;i--)
{
while(hop&&w[st[hop]]>w[i])
li[st[hop]]=i+1,hop--;
st[++hop]=i;
if(i==1)
while(hop) li[st[hop]]=i,hop--;
}
}
lint fsum[N],bsum[N];
void baka()
{
for(int i=1;i<=n;i++)
fsum[i]=fsum[li[i]-1]+w[i]*(i-li[i]+1);
for(int i=n;i;i--)
bsum[i]=bsum[ri[i]+1]+w[i]*(ri[i]-i+1);
} struct ques
{
int l,r,id;
bool friend operator < (ques a,ques b)
{
if(bl[a.l]!=bl[b.l]) return bl[a.l]<bl[b.l];
return bl[a.r]<bl[b.r];
}
}q[N]; lint prt[N],tmp; int main()
{
read(n),read(m),bsize=ceil(sqrt(n));
for(int i=1;i<=n;i++) read(w[i]),bl[i]=(i-1)/bsize+1;
rkk();
is();
baka();
for(int i=1;i<=m;i++) read(q[i].l),read(q[i].r),q[i].id=i;
sort(q+1,q+1+m);
int l=1,r=1;tmp=w[1];
for(int i=1;i<=m;i++)
{
while(r<q[i].r){r++;tmp+=fsum[r]-fsum[rmq(l,r)]+((rmq(l,r)-l+1)*w[rmq(l,r)]);}
while(l>q[i].l){l--;tmp+=bsum[l]-bsum[rmq(l,r)]+((r-rmq(l,r)+1)*w[rmq(l,r)]);}
while(r>q[i].r){tmp-=fsum[r]-fsum[rmq(l,r)]+((rmq(l,r)-l+1)*w[rmq(l,r)]);r--;}
while(l<q[i].l){tmp-=bsum[l]-bsum[rmq(l,r)]+((r-rmq(l,r)+1)*w[rmq(l,r)]);l++;}
prt[q[i].id]=tmp;
}
for(int i=1;i<=m;i++) printf("%lld\n",prt[i]);
return 0;
}
[HNOI2016]序列(莫队,RMQ)的更多相关文章
- BZOJ.4540.[HNOI2016]序列(莫队/前缀和/线段树 单调栈 RMQ)
BZOJ 洛谷 ST表的一二维顺序一定要改过来. 改了就rank1了哈哈哈哈.自带小常数没办法. \(Description\) 给定长为\(n\)的序列\(A_i\).\(q\)次询问,每次给定\( ...
- BZOj 4540: [Hnoi2016]序列 [莫队 st表 预处理]
4540: [Hnoi2016]序列 题意:询问区间所有子串的最小值的和 不强制在线当然上莫队啦 但是没想出来,因为不知道该维护当前区间的什么信息,维护前后缀最小值的话不好做 想到单调栈求一下,但是对 ...
- 【BZOJ4540】[Hnoi2016]序列 莫队算法+单调栈
[BZOJ4540][Hnoi2016]序列 Description 给定长度为n的序列:a1,a2,…,an,记为a[1:n].类似地,a[l:r](1≤l≤r≤N)是指序列:al,al+1,…,a ...
- [BZOJ4540][HNOI2016]序列 莫队
4540: [Hnoi2016]序列 Time Limit: 20 Sec Memory Limit: 512 MB Description 给定长度为n的序列:a1,a2,…,an,记为a[1:n ...
- [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 ...
- 洛谷P3246 [HNOI2016]序列 [莫队]
传送门 思路 看到可离线.无修改.区间询问,相信一定可以想到莫队. 然而,莫队怎么转移是个大问题. 考虑\([l,r]\rightarrow[l,r+1]\)时答案会怎样变化?(左端点变化时同理) \ ...
- bzoj 4540: [Hnoi2016]序列 莫队
题目: 给定长度为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[s:t]是a ...
- BZOJ 4540 [Hnoi2016]序列 | 莫队 详细题解
传送门 BZOJ 4540 题解 --怎么说呢--本来想写线段树+矩阵乘法的-- --但是嘛--yali的机房太热了--困--写不出来-- 于是弃疗,写起了莫队.(但是我连莫队都想不出来!) 首先用单 ...
- 【BZOJ4540】【HNOI2016】序列 [莫队][RMQ]
序列 Time Limit: 20 Sec Memory Limit: 512 MB[Submit][Status][Discuss] Description 给定长度为n的序列:a1,a2,…,a ...
随机推荐
- 第二章 初始MySQL 语法
1.使用MySQL的优势 运行速度快.MySQL体积小,命令执行的速度快: 使用成本低.MySQL是开源的. 容易使用. 可移植性强.MySQL能够运行于多种系统平台之上,windows,linux, ...
- Spring Security即将弃用WebSecurityConfigurerAdapter配置类
用过WebSecurityConfigurerAdapter的都知道对Spring Security十分重要,总管Spring Security的配置体系.但是马上这个类要废了,你没有看错,这个类将在 ...
- python-利用pymysql获取数据简单使用总结
python-利用pymysql获取数据库中的数据 1.前言 pymysql是一个第三方的模块,使用前需要安装 2.安装 pip install pymysql 3.基本使用 import pymys ...
- 设计模式在实际业务应用中的介绍之3——外观或门面模式Facade对AOP装配业务工厂的应用
在C#中实现的基于外观或门面模式打造的业务应用案例 以前一直没有想过写一些东西来把项目中用到的知识点及技术实现做一个归纳整理并分享出来.现在打算逐渐的把项目中的一些东西整理并分享出来,与大家共勉! 外 ...
- mysql安装后,过一段时间,在命令行无法启动
这种问题主要是MYsql没有启动起来,可以在启动管理中开启mysql此服务即可解决
- 小甲鱼二十一讲 :lambda表达式!!!!
0: lambda x:x*3 lambad x,y=3:x*y 1:def findodd(x): if x%2 == 0 return None else: return x 2:几乎不用 ...
- 100G/40G/25G/10G网络测试解决方案
一.100G概述 随着CDN等视频直播业务和P2P业务的快速发展,带宽的要求越来越高.当前5G业务势头正盛,其基于400G的主干网络通信业务也在积极部署之中.但当前在很多的业务场景中,100G系统的部 ...
- Golang 包管理机制
Golang 包管理机制 1. 历史 在go1.11之前, 并没有官方的包管理机制(Godep算个半官方), 主流的包管理机制有: GoVendor Glide Godep 在go1.11之后, 官方 ...
- BI驾驶舱是什么?BI管理驾驶舱主要内容及特点
BI驾驶舱,顾名思义就是商业智能中让企业管理者对企业的管理能够找到在飞机或汽车驾驶舱里面的驾驶感觉.BI管理驾驶舱系统是专为企业管理层设计的BI分析系统,,是为企业高层打造的虚拟办公场景,有利于更好地 ...
- Vue 源码解读(8)—— 编译器 之 解析(下)
特殊说明 由于文章篇幅限制,所以将 Vue 源码解读(8)-- 编译器 之 解析 拆成了两篇文章,本篇是对 Vue 源码解读(8)-- 编译器 之 解析(上) 的一个补充,所以在阅读时请同时打开 Vu ...