【BZOJ3745】Norma(CDQ分治)

题面

BZOJ

洛谷

题解

这种问题直接做不好做,显然需要一定的优化。考虑\(CDQ\)分治。

现在唯一需要考虑的就是跨越当前中间节点的所有区间如何计算答案了。

从\(mid\)开始向左枚举左端点,考虑右端点的贡献。那么我们在右侧记录两个指针\(p,q\),分别表示左侧的最大值和最小值第一次改变的位置。这两个指针会把整个序列分成三段。

第一段最大值和最小值都是左侧最大最小值,直接计算区间长度和就好了。

第二段是最大值和最小值中一个被改变了,分情况讨论一下,维护右侧的区间最大最小值就可以直接算了。第三部分是最大值和最小值都被改变了,那么把式子写出来,维护一个前缀就好了。

时间复杂度\(O(nlogn)\)。可能实现要仔细想清楚,可以看看代码。

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std;
#define ll long long
#define MAX 500500
#define MOD 1000000000
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
int S(int l,int r){return 1ll*(l+r)*(r-l+1)/2%MOD;}
void add(int &x,int y){x+=y;if(x>=MOD)x-=MOD;if(x<0)x+=MOD;}
int n,ans,a[MAX];
int sm[MAX],sp[MAX],smx[MAX],smn[MAX],smxp[MAX],smnp[MAX],mnv[MAX],mxv[MAX];
void CDQ(int l,int r)
{
if(l==r){add(ans,1ll*a[l]*a[l]%MOD);return;}
int mid=(l+r)>>1;CDQ(l,mid);CDQ(mid+1,r);
int mn=a[mid],mx=a[mid];
sm[mid]=sp[mid]=smx[mid]=smn[mid]=smxp[mid]=smnp[mid]=0;
for(int i=mid+1;i<=r;++i)
if(i==mid+1)
{
mnv[i]=mxv[i]=smx[i]=smn[i]=a[i];
smnp[i]=smxp[i]=1ll*a[i]*i%MOD;
sm[i]=1ll*a[i]*a[i]%MOD;sp[i]=1ll*i*a[i]%MOD*a[i]%MOD;
}
else
{
mnv[i]=min(mnv[i-1],a[i]);
mxv[i]=max(mxv[i-1],a[i]);
add(smn[i]=smn[i-1],mnv[i]);
add(smx[i]=smx[i-1],mxv[i]);
add(smnp[i]=smnp[i-1],1ll*mnv[i]*i%MOD);
add(smxp[i]=smxp[i-1],1ll*mxv[i]*i%MOD);
add(sm[i]=sm[i-1],1ll*mnv[i]*mxv[i]%MOD);
add(sp[i]=sp[i-1],1ll*i*mnv[i]%MOD*mxv[i]%MOD);
}
for(int i=mid,p=mid,q=mid;i>=l;--i)
{
mn=min(mn,a[i]);mx=max(mx,a[i]);
while(p<r&&mnv[p+1]>=mn)++p;
while(q<r&&mxv[q+1]<=mx)++q;
add(ans,1ll*S(mid-i+2,min(p,q)-i+1)*mn%MOD*mx%MOD);
if(p<q)add(ans,((smnp[q]-smnp[p])-1ll*(smn[q]-smn[p])*(i-1)%MOD+MOD)*mx%MOD);
if(q<p)add(ans,((smxp[p]-smxp[q])-1ll*(smx[p]-smx[q])*(i-1)%MOD+MOD)*mn%MOD);
add(ans,(((sp[r]-sp[max(p,q)])-1ll*(sm[r]-sm[max(p,q)])*(i-1)%MOD+MOD)%MOD));
}
}
int main()
{
n=read();
for(int i=1;i<=n;++i)a[i]=read();
CDQ(1,n);printf("%d\n",ans);
return 0;
}

【BZOJ3745】Norma(CDQ分治)的更多相关文章

  1. 【BZOJ3745】[Coci2015]Norma cdq分治

    [BZOJ3745][Coci2015]Norma Description Input 第1行,一个整数N: 第2~n+1行,每行一个整数表示序列a. Output 输出答案对10^9取模后的结果. ...

  2. NORMA2 - Norma [cdq分治]

    题面 洛谷 你有一个长度为n的序列,定义这个序列中每个区间的价值是 \(Cost(i,j)=Min(Ai...Aj)∗Max(Ai...Aj)∗(j−i+1)Cost(i,j)=Min(A_{i}.. ...

  3. 【CF526F】Pudding Monsters cdq分治

    [CF526F]Pudding Monsters 题意:给你一个排列$p_i$,问你有对少个区间的值域段是连续的. $n\le 3\times 10^5$ 题解:bzoj3745 Norma 的弱化版 ...

  4. 【教程】简易CDQ分治教程&学习笔记

    前言 辣鸡蒟蒻__stdcall终于会CDQ分治啦!       CDQ分治是我们处理各类问题的重要武器.它的优势在于可以顶替复杂的高级数据结构,而且常数比较小:缺点在于必须离线操作. CDQ分治的基 ...

  5. BZOJ 2683 简单题 ——CDQ分治

    [题目分析] 感觉CDQ分治和整体二分有着很本质的区别. 为什么还有许多人把他们放在一起,也许是因为代码很像吧. CDQ分治最重要的是加入了时间对答案的影响,x,y,t三个条件. 排序解决了x ,分治 ...

  6. HDU5618 & CDQ分治

    Description: 三维数点 Solution: 第一道cdq分治...感觉还是很显然的虽然题目不能再傻逼了... Code: /*=============================== ...

  7. 初识CDQ分治

    [BZOJ 1176:单点修改,查询子矩阵和]: 1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 200 ...

  8. HDU5322 Hope(DP + CDQ分治 + NTT)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5322 Description Hope is a good thing, which can ...

  9. BZOJ4170 极光(CDQ分治 或 树套树)

    传送门 BZOJ上的题目没有题面-- [样例输入] 3 5 2 4 3 Query 2 2 Modify 1 3 Query 2 2 Modify 1 2 Query 1 1 [样例输出] 2 3 3 ...

随机推荐

  1. 深入解析Java中的装箱和拆箱

    自己主动装箱和拆箱问题是Java中一个老生常谈的问题了,今天我们就来一些看一下装箱和拆箱中的若干问题.本文先讲述装箱和拆箱最主要的东西,再来看一以下试笔试中常常遇到的与装箱.拆箱相关的问题. 下面是本 ...

  2. MapReduce -- 最短路径

    示例: 给出各个节点到相邻节点的距离,要求算出初始节点到各个节点的最短路径. 数据: A (B,) (D,) B (C,) (D,) C (E,) D (B,) (C,) (E,) E (A,) (C ...

  3. SEO优化上首页之搜索引擎排名规则

    搜索引擎建立索引的网页数以万亿计,用户搜索的关键词也是海量,如果每个用户提交搜索请求后,搜索引擎都去数以万亿的索引中重新排名网页,效率将非常低下.根据2-8法则,80%是查询是集中在相同的20%内容上 ...

  4. IIS发布问题

    下午发布一个IIS ,出现一个很奇葩的问题,在本地跑代码运行都正常,但是发布到IIS上后 访问提示: CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET\Framewo ...

  5. mapreduce 多种输入

    1.多路径输入 1)FileInputFormat.addInputPath 多次调用加载不同路径 FileInputFormat.addInputPath(job, new Path("h ...

  6. Kubernetes学习之路(二十)之K8S组件运行原理详解总结

    目录 一.看图说K8S 二.K8S的概念和术语 三.K8S集群组件 1.Master组件 2.Node组件 3.核心附件 四.K8S的网络模型 五.Kubernetes的核心对象详解 1.Pod资源对 ...

  7. cocos2d-x学习记录1——图片显示

    这篇算是cocos2d-x入门篇,显示一张图片即可. 观察工程中HelloWorld的结构,包含AppDelegate和HelloWorldScene两个类文件,AppDelegate中包含基本的处理 ...

  8. webVR全景图多种方案实现(pannellum,aframe,Krpano,three,jquery-vrview)

    前言 有一篇文章我说了H5实现全景图预览,全景视频播放的原理,有需要的小伙伴可以自行去看一下 今天我就拿出我的实践干货出来,本人实测实测过 需求 老板:我需要可以上传全景图片,然后手机网站上都可以36 ...

  9. 9、Dockerfile实战-Nginx

    上一节我们详解Dockerfile之后,现在来进行实战.我们通过docker build来进行镜像制作. build有如下选项: [root@localhost ~a]# docker build - ...

  10. docker 部署Spring Boot:Docker化Spring Boot应用程序

    第一章 1.创建项目存放目录 mkdir /root/sproot -p 2.准备好Spring Boot应用程序 jar 包 testrest.jar 第二章 1. 安装docker 在所有节点执行 ...