P3246 [HNOI2016]序列(莫队+单调栈+ST表)

[HNOI2016]序列

Tea神题解 Kelin神题解

对于莫队算法最主要的是如何快速算出[l,r]→[l,r+1][l,r]\to[l,r+1][l,r][l,r+1]对答案的贡献的变化。
当询问区间发生上述变化时[l,r]→[l,r+1][l,r]\to [l,r+1][l,r][l,r+1]不难发现子区间增加这些:[l,r+1],[l+1,r+1],…,[r,r+1],[r+1,r+1][l,r+1],[l+1,r+1],\dots,[r,r+1],[r+1,r+1][l,r+1],[l+1,r+1],,[r,r+1],[r+1,r+1]总共r−l+2r-l+2rl+2个子区间[l→r+1,r+1][l\to r+1,r+1][lr+1,r+1],需要求出他们对答案的贡献即每个区间的区间最小值之和。

考虑求出[l,r+1][l,r+1][l,r+1]区间最小值的位置是ppp,不难得知这些子区间[l→p,r+1][l\to p,r+1][lp,r+1]的最小值都是apa_pap,这部分对答案的贡献是ap×(p−l+1)a_p×(p-l+1)ap×(pl+1)这里可以用ST表预处理快速求出。

而对于这些子区间[p+1→r+1,r+1][p+1\to r+1,r+1][p+1r+1,r+1]
预处理fif_ifi:表示以iii为区间右端点的最小值之和
fi=fLi+ai×(i−Li)f_i=f_{L_i}+a_i×(i-L_i)fi=fLi+ai×(iLi)
LiL_iLi表示iii左边第一个小于等于aia_iai的位置。(可以用单调栈预处理)

不难发现一定有xxx使得Lx=pL_x=pLx=p于是有fr+1=ar+1×(r+1−Lr+1)+⋯+ax×(x−p)+fpf_{r+1}=a_{r+1}×(r+1-L_{r+1})+\dots+a_x×(x-p)+f_pfr+1=ar+1×(r+1Lr+1)++ax×(xp)+fp
于是子区间[p+1→r+1,r+1][p+1\to r+1,r+1][p+1r+1,r+1]对答案的贡献是fr+1−fpf_{r+1}-f_pfr+1fp

对于[l,r]→[l−1,r][l,r]\to[l-1,r][l,r][l1,r]可以效仿移动右端点的方式预处理RiR_iRi以及gig_igi即可。

时间复杂度O(nlog⁡n+nn)O(n\log n+n\sqrt{n})O(nlogn+nn)

注意莫队首先移动右端点因为初始化时l=1,r=0l=1,r=0l=1,r=0

#include<cmath>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
using pii=pair<int,int>;
using ll=long long;
constexpr int N=100010;
pii ST[N][22];
int lg[N];
int a[N],n,m;
int L[N],R[N],stk[N],top;
ll f[N],g[N];
int sz,pos[N];
void init(int n)
{lg[1]=0;for(int i=2;i<=n;i++) lg[i]=lg[i>>1]+1;for(int i=1;i<=n;i++) ST[i][0]={a[i],i};for(int k=1;k<=lg[n];k++)for(int i=1;i+(1<<k)-1<=n;i++)  ST[i][k]=min(ST[i][k-1],ST[i+(1<<k-1)][k-1]);top=0;for(int i=1;i<=n;i++){while(top&&a[stk[top]]>a[i]) top--;L[i]=stk[top];stk[++top]=i;}stk[top=0]=n+1;for(int i=n;i>=1;i--){while(top&&a[stk[top]]>a[i]) top--;R[i]=stk[top];stk[++top]=i;}for(int i=1;i<=n;i++) f[i]=f[L[i]]+1ll*(i-L[i])*a[i];for(int i=n;i>=1;i--)g[i]=g[R[i]]+1ll*(R[i]-i)*a[i];sz=sqrt(n);for(int i=1;i<=n;i++) pos[i]=i/sz;}
int query(int l,int r)// [l,r]最小值的位置
{int k=lg[r-l+1];return min(ST[l][k],ST[r-(1<<k)+1][k]).second;
}
struct node
{int l,r;int id;bool operator<(const node&o)const{return pos[l]<pos[o.l]||pos[l]==pos[o.l]&&r<o.r;}
}q[N];
ll calcR(int l,int r)
{int p=query(l,r);return 1ll*a[p]*(p-l+1)+f[r]-f[p];
}
ll calcL(int l,int r)
{int p=query(l,r);return 1ll*a[p]*(r-p+1)+g[l]-g[p];
}
ll ans[N],res;
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);cin>>n>>m;for(int i=1;i<=n;i++) cin>>a[i];init(n);for(int i=1;i<=m;i++){int l,r;cin>>l>>r;q[i]={l,r,i};}sort(q+1,q+1+m);int l=1,r=0;for(int i=1;i<=m;i++){while(r<q[i].r) res+=calcR(l,++r);//首先考虑右端点while(r>q[i].r) res-=calcR(l,r--);while(l<q[i].l) res-=calcL(l++,r);while(l>q[i].l) res+=calcL(--l,r);ans[q[i].id]=res;}for(int i=1;i<=m;i++) cout<<ans[i]<<'\n';return 0;
}

注意我改了2小时,对比代码才改出来,无语了~~~
要加油哦~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319000.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P6672-[清华集训2016]你的生命已如风中残烛【结论】

正题 题目链接:https://www.luogu.com.cn/problem/P6672 题目大意 长度为mmm的序列aaa&#xff0c;有nnn个数字不是000&#xff0c;其他m−nm-nm−n个是000。要求重排后有多少方案满足 ∀x,∑i1xai≥i\forall x,\sum_{i1}^xa_i\geq i∀x,i1∑x​ai​≥i 其中m∑i1naim\sum_{i…

牛客题霸 反转链表 C++题解/答案

题目描述 输入一个链表&#xff0c;反转链表后&#xff0c;输出新链表的表头。 示例1 输入 复制 {1,2,3} 返回值 复制 {3,2,1} 题解&#xff1a; 如果用偷懒的方法&#xff0c;可以用vector来存链表内容&#xff0c;然后来个翻转&#xff08;vector自带&#xff09;即可 但是…

【.NET Core项目实战-统一认证平台】第五章 网关篇-自定义缓存Redis

上篇文章【.NET Core项目实战-统一认证平台】第四章 网关篇-数据库存储配置&#xff08;2&#xff09;我们介绍了2种网关配置信息更新的方法和扩展Mysql存储&#xff0c;本篇我们将介绍如何使用Redis来实现网关的所有缓存功能&#xff0c;用到的文档及源码将会在GitHub上开源&a…

P5934-[清华集训2012]最小生成树【最小割】

正题 题目链接:https://www.luogu.com.cn/problem/P5934 题目大意 给出nnn个点mmm条边的一张图&#xff0c;再加入一条边(u,v,L)(u,v,L)(u,v,L)求至少删掉多少条边可以使得这条边即在最小生成树上又在最大生成树上。 1≤n≤2104,1≤m≤21051\leq n\leq 2\times 10^4,1\leq m\…

广州.net俱乐部12月份ABP框架活动场地征集、志愿者征集、合作讲师\副讲师征集...

大家好&#xff0c;我在<被低估的.net(上) - 微软MonkeyFest 2018广州分享会活动回顾>一文中提到&#xff0c;我将在12月份搞一场ABP框架活动&#xff0c;现向大家征集活动场地、志愿者、合作讲师\副讲师。活动课程标题是&#xff1a;如何用ABP框架快速完成项目这是内容大…

4152. [AMPPZ2014]The Captain(稠密图最短路)

4152. [AMPPZ2014]The Captain 显然稠密图的边数时n2n^2n2量级&#xff0c;我们不可能把所有边建立出来&#xff0c;这时候通常寻求一些性质详细见【论题选编】稠密图最短路 针对本题我们可以先这样考虑&#xff0c;假设每个点有且只有一维信息&#xff0c;那么任意两点之间的…

牛客题霸 二分查找 C++题解/答案

牛客题霸 二分查找 C题解/答案 题目描述 请实现有重复数字的有序数组的二分查找。 输出在数组中第一个大于等于查找值的位置&#xff0c;如果数组中不存在这样的数&#xff0c;则输出数组长度加一。 示例1 输入 复制 5,4,[1,2,4,4,5] 返回值 复制 3 题解&#xff1a; 二分模…

CF1446F-Line Distance【计算几何,树状数组,二分】

正题 题目链接:https://www.luogu.com.cn/problem/CF1446F 题目大意 给出nnn个点&#xff0c;求所有点对构成的直线中与原点距离第kkk小的距离 2≤n≤105,1≤k≤n(n−1)22\leq n\leq 10^5,1\leq k\leq \frac{n(n-1)}{2}2≤n≤105,1≤k≤2n(n−1)​ 解题思路 二分还是挺显然的…

牛客题霸 判断链表中是否有环 C++题解/答案

牛客题霸 判断链表中是否有环 C题解/答案 题目描述 判断给定的链表中是否有环 扩展&#xff1a; 你能给出空间复杂度的解法么&#xff1f; 题解&#xff1a; 在这介绍一个简便的方法&#xff1a;快慢指针 就是&#xff1a;一个指针走两步&#xff0c;一个指针走一步 快慢指…

为什么是容器,Docker和Kubernetes?

如果你是一名IT行业的从业者&#xff0c;还没有听说过以上3个词的任何一个&#xff0c;抱歉&#xff0c;你可以改行了&#xff1b;如果你是一名技术人员&#xff0c;无论你是程序员&#xff0c;测试人员&#xff0c;运维工程师还是时髦的DevOps工程师&#xff0c;你还没有运行过…

P2685 [TJOI2012]桥(最短路+线段树)

P2685 [TJOI2012]桥 xcxcli题解 下面思路仿照上述题解&#xff0c;代码基本照抄上述题解 u⇝vu\leadsto vu⇝v表示uuu到vvv的最短路 u→vu\to vu→v表示uuu和vvv直接相连的边 d1ud1_ud1u​表示1⇝u1\leadsto u1⇝u的最短路 dnudn_udnu​表示n⇝vn\leadsto vn⇝v的最短路 题意化…

牛客题霸 [斐波那契数列] C++题解/答

斐波那契数列 题目描述 大家都知道斐波那契数列&#xff0c;现在要求输入一个整数n&#xff0c;请你输出斐波那契数列的第n项&#xff08;从0开始&#xff0c;第0项为0&#xff0c;第1项是1&#xff09;。 n<39 题解&#xff1a; 斐波那契数列。。递推的基础题目 众所周…

一份来自28岁.NET老程序员的自白

写在前面很幸运&#xff0c;28岁的我头发还没有掉光&#xff0c;更幸运的是28岁的我开始了博客园的写作生活&#xff01;这样的技术分享经历让我拓展了自己的朋友圈&#xff01;有幸结识了像张善友张队&#xff08;连续13年的微软MVP&#xff09;&#xff0c;大石头(NewLife团队…

P5825-排列计数【EGF,NTT】

正题 题目链接:https://www.luogu.com.cn/problem/P5825 题目大意 对于每个kkk&#xff0c;求有多少个长度为nnn的排列有kkk个位置上升。 1≤n≤21051\leq n\leq 2\times 10^51≤n≤2105 解题思路 考虑到同时考虑大于和小于十分麻烦&#xff0c;设fif_ifi​表示钦定iii个上升…

牛客题霸 [数组中出现次数超过一半的数字] C++题解/答案

牛客题霸 [数组中出现次数超过一半的数字] C题解/答案 题解&#xff1a; 题意很明确 跑一遍for循环&#xff0c;统计每个数出现的大小 然后再跑一边循环&#xff0c;查看是否存在大于一半的情况 注意题目要求是大于&#xff0c;没有等于 代码&#xff1a; class Solution {…

2725. [Violet 6]故乡的梦(删边最短路同[TJOI2012]桥)

2725. [Violet 6]故乡的梦 和P2685 [TJOI2012]桥可以说是一模一样&#xff0c;判断u,vu,vu,v是否在最短路径上可以利用之前预处理的id[]详细看代码。 #include<map> #include<queue> #include<cstring> #include<iostream> #include<algorithm>…

谈谈.NET Core中基于Generic Host来实现后台任务

前言很多时候&#xff0c;后台任务对我们来说是一个利器&#xff0c;帮我们在后面处理了成千上万的事情。在.NET Framework时代&#xff0c;我们可能比较多的就是一个项目&#xff0c;会有一到多个对应的Windows服务&#xff0c;这些Windows服务就可以当作是我们所说的后台任务…

P3971-[TJOI2014]Alice and Bob【贪心】

正题 题目链接:https://www.luogu.com.cn/problem/P3971 题目大意 一个1∼n1\sim n1∼n的一个排列&#xff0c;设aia_iai​表示以iii结尾的最长上升子序列长度&#xff0c;bib_ibi​表示以iii开头的最长下降子序列长度。 给出序列aaa求序列bbb的最大和。 1≤n≤1051\leq n\l…

牛客题霸 [平衡二叉树] C++题解/答案

牛客题霸 [平衡二叉树] C题解/答案 题目描述 输入一棵二叉树&#xff0c;判断该二叉树是否是平衡二叉树。 在这里&#xff0c;我们只需要考虑其平衡性&#xff0c;不需要考虑其是不是排序二叉树 题解&#xff1a; 今天上数据结构刚考了平衡二叉树 平衡二叉树定义(AVL)&…

2018 KubeCon + CloudNativeCon完美落幕,行云献力

2018年11月13-15日&#xff0c;由云原生计算基金会&#xff08;CNCF&#xff09;组织的KubeConCloudNativeCon首次登陆中国。经过了三天的技术交流和展示&#xff0c;大会随着15日下午最后一个议程的结束而完美落幕。作为云原生领域全球最大的峰会&#xff0c;KubeConCloudNati…