题目描述

原题来自:HNOI 2002

Tiger 最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况。

Tiger 拿出了公司的账本,账本上记录了公司成立以来每天的营业额。分析营业情况是一项相当复杂的工作。由于节假日,大减价或者是其他情况的时候,营业额会出现一定的波动,当然一定的波动是能够接受的,但是在某些时候营业额突变得很高或是很低,这就证明公司此时的经营状况出现了问题。

经济管理学上定义了一种最小波动值来衡量这种情况:记该天以前某一天的营业额为ai,该天营业额为 b,则该天的最小波动值min | ai-b | ,当最小波动值越大时,就说明营业情况越不稳定。而分析整个公司的从成立到现在营业情况是否稳定,只需要把每一天的最小波动值加起来就可以了。

你的任务就是编写一个程序帮助 Tiger 来计算这一个值,第一天的最小波动值为第一天的营业额。

一句话题意

给出一个n个数的数列{an},对于第 i 个元素ai ,定义fi =min | ai - ai|,其中1<=j<=i,fi=a1 。求 Σfi

输入格式

第一行为正整数,表示该公司从成立一直到现在的天数;

接下来的n行每行有一个正整数,表示第 i 天公司的营业额ai 。

输出格式

仅有一个正整数,即每一天最小波动的和,结果不超过1<<31 。

样例

样例输入

6
5
1
2
5
4
6

样例输出

12

样例说明

数据范围与提示

对于全部数据,1<=n<=215 ,ai<=106

_________________________________

平衡树中查找前驱后继,然后和当前值取差,取较小的加入最终结果。

继续熟悉FHQ_TREAP

_________________________________

 1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=(1<<15)+10;
4 const int inf=1e7;
5 int n;
6 struct node
7 {
8 int lc,rc,val,rd,siz;
9 }tr[maxn];
10 int cnt,root;
11 long long ans;
12 int newnode(int v)
13 {
14 ++cnt;
15 tr[cnt].lc=tr[cnt].rc=0;
16 tr[cnt].val=v;
17 tr[cnt].rd=rand();
18 tr[cnt].siz=1;
19 return cnt;
20 }
21 void update(int x)
22 {
23 tr[x].siz=tr[tr[x].lc].siz+tr[tr[x].rc].siz+1;
24 }
25 int merge(int x,int y)
26 {
27 if(x*y==0)return x+y;
28 if(tr[x].rd<tr[y].rd)
29 {
30 tr[x].rc=merge(tr[x].rc,y);
31 update(x);
32 return x;
33 }
34 else
35 {
36 tr[y].lc=merge(x,tr[y].lc);
37 update(y);
38 return y;
39 }
40 }
41 void split(int cur,int k,int &x,int &y)
42 {
43 if(!cur)x=y=0;
44 else
45 {
46 if(tr[cur].val<=k)
47 {
48 x=cur;
49 split(tr[cur].rc,k,tr[cur].rc,y);
50 }
51 else
52 {
53 y=cur;
54 split(tr[cur].lc,k,x,tr[cur].lc);
55 }
56 update(cur);
57 }
58 }
59 int kth(int now,int v)
60 {
61 int cur=now;
62 while(cur)
63 {
64 if(tr[tr[cur].lc].siz+1==v)return tr[cur].val;
65 else if(tr[tr[cur].lc].siz>=v)cur=tr[cur].lc;
66 else v-=tr[tr[cur].lc].siz+1,cur=tr[cur].rc;
67 }
68 return inf;
69 }
70 void work(int v)
71 {
72 int x,y,tp=inf,tpp;
73 split(root,v,x,y);
74 tpp=kth(x,tr[x].siz);
75 tp=tpp==inf?inf:v-tpp;
76 tpp=kth(y,1);
77 tp=tpp==inf?tp:min(tp,tpp-v);
78 if(tp!=inf)ans+=tp;
79 root=merge(merge(x,newnode(v)),y);
80 }
81 int main()
82 {
83 scanf("%d",&n);
84 for(int x,i=0;i<n;++i)
85 {
86 scanf("%d",&x);
87 if(i==0)ans=x;
88 work(x);
89 }
90 cout<<ans;
91 return 0;
92 }

LOJ10043的更多相关文章

随机推荐

  1. IntelliJ IDEA无法新建类解决办法

    IntelliJ IDEA无法新建类解决办法 灿夏 2018-07-14 08:50:05  4891  收藏 1 展开 原文地址 IntelliJ IDEA使用教程 (总目录篇) [原文地址](ht ...

  2. Android驱动学习-app调用内核驱动过程(驱动框架回顾)

    考研已经过去了,android驱动的学习也断了半年多了,现在重新捡起来学习,回顾一下Android驱动的大体框架. Android系统的核心是java,其有一个David虚拟机.Android-app ...

  3. 对CROS OPTIONS预检请求的一些思考

    前后端分离模大势所趋,跨域问题更是老生常谈. 问题背景: 浏览器最基本的安全规范-同源策略.所谓同源是指域名.协议.端口相同.不同源的浏览器脚本(javascript.ActionScript.can ...

  4. Phoenix-4.14-cdh5.14.2与hbase-1.2.0-cdh5.14.2集成测试

    Phoenix介绍: 针对hbase开发的第三方插件,目前已贡献给Apache,顶级项目    Phoenix是构建在HBase上的一个SQL层  可以使用类似于操作mysql的标准sql语句,作为h ...

  5. 痞子衡嵌入式:MCUBootUtility v3.0发布,开始支持LPC, Kinetis啦

    -- 痞子衡维护的NXP-MCUBootUtility工具距离上一个版本(v2.4.0)发布过去2个半月了,这一次痞子衡为大家带来了全新版本v3.0.0,从这个版本开始,NXP-MCUBootUtil ...

  6. 在.NET Core中使用Channel(三)

    到目前为止,我们一直在使用所谓的"Unbounded"通道.你会注意到,当我们创建通道时,我们这样做: var myChannel = Channel.CreateUnbounde ...

  7. C# 中的 null 包容运算符 “!” —— 概念、由来、用法和注意事项

    在 2020 年的最后一天,博客园发起了一个开源项目:基于 .NET 的博客引擎 fluss,我抽空把源码下载下来看了下,发现在属性的定义中,有很多地方都用到了 null!,如下图所示: 这是什么用法 ...

  8. Angular入门到精通系列教程(7)- 组件(@Component)基本知识

    1. 概述 2. 创建Component 组件模板 视图封装模式 特殊的选择器 :host inline-styles 3. 总结 环境: Angular CLI: 11.0.6 Angular: 1 ...

  9. Spring Boot 计划任务中的一个“坑”

    计划任务功能在应用程序及其常见,使用Spring Boot的@Scheduled 注解可以很方便的定义一个计划任务.然而在实际开发过程当中还应该注意它的计划任务默认是放在容量为1个线程的线程池中执行, ...

  10. 【JavaWeb】HTML&CSS 基础

    HTML&CSS 基础 HTML 基础 HTML 标签 HTML标题:HTML 标题(Heading)是通过 h1 - h6 等标签进行定义的. HTML段落: HTML 段落是通过 p 标签 ...