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的更多相关文章
随机推荐
- ESXi 中重新启动管理代理
使用直接控制台用户界面 (DCUI)重启管理代理: 连接到您的 ESXi 主机的控制台. 按 F2 自定义系统. 以 root 身份登录. 使用上下箭头导航至故障排除选项>重新启动管理代理. 按 ...
- Vue项目如何打包问题总结
当我们将 vue 项目完成后,面临的就是如何将项目进行打包上线,放到服务器中.我使用的是 vue-cli(simple) 脚手架,所以就讲一下如何将项目进行打包,并放到 tomcat 上. 先来描述一 ...
- 高效实用linux命令之-history
History(历史)命令用法 15 例 如果你经常使用 Linux 命令行,那么使用 history(历史)命令可以有效地提升你的效率.本文将通过实例的方式向你介绍 history 命令的 15 个 ...
- 自动化运维工具-Ansible之3-playbook
自动化运维工具-Ansible之3-playbook 目录 自动化运维工具-Ansible之3-playbook PlayBook初识 YAML语法 PlayBook部署httpd PlayBook实 ...
- 这些JS技巧,看看你是否都会用?
问题1:以下代码在浏览器控制台上会打印什么? var a = 10; function foo() { console.log(a); // ?? var a = 20; } foo(); 问题2:如 ...
- Spring框架的IOC(控制反转)
1.1.IoC是什么 Ioc-Inversion of Control,即"控制反转",不是什么技术,而是一种设计思想.在Java开发中,Ioc意味着将你设计好的对象交给容器控制, ...
- Kafka知识总结及面试题
目录 概念 Kafka基础概念 命令行 Kafka 数据存储设计 kafka在zookeeper中存储结构 生产者 生产者设计 消费者 消费者设计 面试题 kafka设计 请说明什么是Apache K ...
- 《Go 语言并发之道》读后感 - 第一章
<Go 语言并发之道>读后感 - 第一章 前言 人生路漫漫,总有一本书帮助你在某条道路上打通任督二脉,<Go 语言并发之道>就是我作为一个 Gopher 道路上的一本打通任督二 ...
- apply 和 call的用法、区别
1.JavaScript中函数是对象的方法,如果一个函数不是js对象的方法那一定是全局对象的函数,每个函数的对象都有apply和call方法,即每个对象都有call and apply apply:调 ...
- reactjs踩坑记
getFieldDecorator 提示错误 Warning: `getFieldDecorator` will override `value`, so please don't set `valu ...