LOJ10043
题目描述
原题来自: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的更多相关文章
随机推荐
- idea2020 没有 Autoscroll from Source
2018版本: 2020版本: 最后在官网的网站中找到了解决方案,原来是改名了: 网址:https://intellij-support.jetbrains.com/hc/en-us/communit ...
- C#——时间之不同国家的显示格式
对于时间的显示,不同的地方有不同的时间格式,代码如下: public class Common_DateFormat { public Common_DateFormat() { // // TODO ...
- 万恶的NPE差点让我半个月工资没了
引言 最近看到<阿里巴巴Java开发手册>(公众号回复[开发手册]免费获取)第11条规范写到: 防止 NPE ,是程序员的基本修养 NPE(Null Pointer Exception)一 ...
- [leetcode]114. Flatten Binary Tree to Linked List由二叉树构建链表
/* 先序遍历构建链表,重新构建树 */ LinkedList<Integer> list = new LinkedList<>(); public void flatten( ...
- go语言的下载、安装、配置
一.下载 Go 语言支持以下系统: Linux FreeBSD Mac OS X(也称为 Darwin) Windows 安装包下载地址为:https://golang.org/dl/. 如果打不开可 ...
- CSS系列 (05):浮动详解
浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止.由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样. -- W3C 文字环绕 float可以 ...
- js概念和ECMAScript
概念 就是一门浏览器客户端的脚本语言 运行在客户端浏览器中的,每一个浏览器都有JavaScript的解析引擎. 脚本语言,不需要编译,直接就可以被浏览器解析执行. 好处: 可以增强一些用户的 ...
- MySQL 标识符到底区分大小写么——官方文档告诉你
最近在阿里云服务器上部署一个自己写的小 demo 时遇到一点问题,查看 Tomcat 日志后定位到问题出现在与数据库服务器交互的地方,执行 SQL 语句时会返回 指定列.指定名 不存在的错误.多方查证 ...
- 分装button组件引发的内存泄漏问题
这个问题其实一开始在vue里写的时候并没有注意到这一点,也没有报错,直到在react里写的时候给我报了一堆错之后,经各种磨烂之后最终找到是分装button组件的问题,既然找到问题在哪就好办了 直接先上 ...
- Openstack dashboard 仪表盘服务 (八)
Openstack dashboard 仪表盘服务 (八) # 说明: 这个部分将描述如何在控制节点上安装和配置仪表板.dashboard仅在核心服务中要求认证服务.你可以将dashboard与其他服 ...