题目描述

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

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

当最小波动值越大时,就说明营业情况越不稳定。

而分析整个公司的从成立到现在营业情况是否稳定,只需要把每一天的最小波动值加起来就可以了。你的任务就是编写一个程序帮助Tiger来计算这一个值。

第一天的最小波动值为第一天的营业额。

输入输出格式

输入格式:

输入由文件’turnover.in’读入。

第一行为正整数n(n<=32767) ,表示该公司从成立一直到现在的天数,接下来的n行每行有一个整数ai(|ai|<=1000000) ,表示第i天公司的营业额,可能存在负数。

输出格式:

输入输出样例

输入样例#1:

6
5
1
2
5
4
6
输出样例#1:

12

说明

结果说明:5+|1-5|+|2-1|+|5-5|+|4-5|+|6-5|=5+4+1+0+1+1=12

题目说的很清楚了,只是“第一天的最小波动值为第一天的营业额”这句话需要注意。那么,由于这题的特殊性,并不是最大值或最小值,而是最接近的,所以不适合用线段树等算法做。那用什么?BST是不错的选择。但是BST容易被卡啊,怎么办?写了个splay这个splay要用到的操作有Zig,Zag,splay,insert,searchpred,searchsucc。其他的不需要什么。splay这东西的精髓就是:频繁一点调用splay。还要注意的是,营业额有负数,还有0。。。

 #include<cstdio>
 #include<cstring>
 #include<algorithm>
 using namespace std;
 struct Splay{
     int Lid,Rid,val,fa;
 }T[];
 int ROOT,ans,n;
 int read(){
     ,f=; char ch=getchar();
     '){if (ch=='-') f=-f; ch=getchar();}
     +ch-',ch=getchar();
     return x*f;
 }
 void Insert(int x,int v,int cnt,int ff){
     <<)){T[x].val=v; T[x].fa=ff; return;}
     if (v<T[x].val){
         if (!T[x].Lid) T[x].Lid=cnt; Insert(T[x].Lid,v,cnt,x);
     }else{
         if (!T[x].Rid) T[x].Rid=cnt; Insert(T[x].Rid,v,cnt,x);
     }
 }
 int Search_Succ(int x){
     if (T[x].Rid){
         for (int y=T[x].Rid; y; y=T[y].Lid) if (!T[y].Lid) return T[y].val;
     }<<);
 }
 int Search_Pred(int x){
     if (T[x].Lid){
         for (int y=T[x].Lid; y; y=T[y].Rid) if (!T[y].Rid) return T[y].val;
     }<<);
 }
 void Zig(int x){
     int y=T[x].fa; T[y].Lid=T[x].Rid;
     if (T[x].Rid) T[T[x].Rid].fa=y;
     T[x].fa=T[y].fa;
     if (T[y].fa){
         if (y==T[T[y].fa].Lid) T[T[y].fa].Lid=x; else T[T[y].fa].Rid=x;
     }
     T[y].fa=x,T[x].Rid=y;
 }
 void Zag(int x){
     int y=T[x].fa; T[y].Rid=T[x].Lid;
     if (T[x].Lid) T[T[x].Lid].fa=y;
     T[x].fa=T[y].fa;
     if (T[y].fa){
         if (y==T[T[y].fa].Lid) T[T[y].fa].Lid=x; else T[T[y].fa].Rid=x;
     }
     T[y].fa=x,T[x].Lid=y;
 }
 void splay(int x){
     for (int y=T[x].fa; y; y=T[x].fa){
         if (!T[y].fa){if (x==T[y].Lid) Zig(x); else Zag(x); break;}
         if (x==T[y].Lid){
             if (y==T[T[y].fa].Lid) Zig(y),Zig(x); else Zig(x),Zag(x);
         }else{
             if (y==T[T[y].fa].Rid) Zag(y),Zag(x); else Zag(x),Zig(x);
         }
     }
     ROOT=x;
 }
 int main(){
     memset(T,,;
     n=read(); ; i<=n; i++) T[i].val=-(<<);
     T[].val=read(),ans=T[].val;
     ; i<=n; i++){
         int x=read();
         Insert(ROOT,x,i,); splay(i);
         int suc=Search_Succ(i),pre=Search_Pred(i);
         ans+=min(abs(suc-x),abs(pre-x));
     }
     printf("%d",ans);
     ;
 }

Ps:C党还可用STL里面的set实现(代码短小而精悍)。

[HNOI2002] 营业额统计的更多相关文章

  1. BZOJ1588: [HNOI2002]营业额统计[BST]

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 14151  Solved: 5366[Submit][Sta ...

  2. BZOJ 1588: [HNOI2002]营业额统计

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 14396  Solved: 5521[Submit][Sta ...

  3. BZOJ 1588: [HNOI2002]营业额统计 双向链表 / splay / treap

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

  4. BZOJ1588 HNOI2002 营业额统计 [Splay入门题]

    [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 4128  Solved: 1305 Description 营业额统计 ...

  5. bzoj 1588: [HNOI2002]营业额统计 treap

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 13902  Solved: 5225[Submit][Sta ...

  6. 数据结构:(平衡树,链表)BZOJ 1588[HNOI2002]营业额统计

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 12173  Solved: 4354[Submit][Sta ...

  7. bzoj1588 [HNOI2002]营业额统计(Treap)

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 11485  Solved: 4062[Submit][Sta ...

  8. 1588: [HNOI2002]营业额统计

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 9203  Solved: 3097[Submit][Stat ...

  9. 【链表】BZOJ1588: [HNOI2002]营业额统计

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 17555  Solved: 7179[Submit][Sta ...

  10. [HNOI2002]营业额统计_Treap

    [HNOI2002]营业额统计 题目大意:给你一串n数序列,对于每一个刚输入的数a,找到一个前面的数k,使得|a-k|最小. 注释:$n<=32767,ai<=10^6$. 想法:刚学Tr ...

随机推荐

  1. 最小 base64 图片

    http://www.webhek.com/post/base64-encode-of-1x1px-transparent-gif.html Base64 Encode 1x1px透明GIF图片 Ba ...

  2. Jenkins参数化构建(三)之 Jenkins从文件中读取运行参数

    安装Extended Choice Parameter插件 选择‘参数化构建过程’ maven command line中进行引用 clean test -DsuiteXmlFile=src/main ...

  3. C#判断数据类型的简单示例代码

    ; Console.WriteLine( "i is an int? {0}",i.GetType()==typeof(int)); Console.WriteLine( &quo ...

  4. C# linq 最大、最小对象的扩展

    public static class LinqExtension { public static T MaxBy<T, TR>(this IEnumerable<T> en, ...

  5. R语言通过loess去除某个变量对数据的影响--CNV分析

    当我们想研究不同sample的某个变量A之间的差异时,往往会因为其它一些变量B对该变量的固有影响,而影响不同sample变量A的比较,这个时候需要对sample变量A进行标准化之后才能进行比较.标准化 ...

  6. python 删除文件夹

    只能删除空文件夹,删除非空文件夹会报错 >>> import os >>> os.rmdir("/tmp/ssh-GyoPWOFZ47") Tr ...

  7. [HTML]html读取本地文件并显示

    <html> <body> <script script type="text/javascript"> function show() { v ...

  8. sass、less是什么,如何使用?

    一个很好的介绍的SASS,LESS的区别的文档,值get 1.背景介绍 CSS 是一门非程序式语言,没有变量.函数.SCOPE(作用域),需要书写大量看似没有逻辑的代码,不方便维护及扩 展,不利于复用 ...

  9. Spring 的@@Autowired 和 @Qualifier注释

    @Autowired spring2.1中允许用户通过@Autowired注解对Bean的属性变量.属性Setter方法以及构造方法进行标注,配合AutowiredAnnotationBeanProc ...

  10. 在不进入Guest OS的情况下,取得Guest OS的IP地址

    因为是个Headless 服务器,总是需要GUI VNC 到 Host OS, 然后进入里面的虚拟机,打 ipconfig / ifconfig  ,非常的不方便. 查了网上,找到上面的方法 1)确保 ...