题目描述

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. 3、使用keepalived高可用LVS实例演示

    回顾: keepalived: vrrp协议的实现: 虚拟路由器: MASTER,BACKUP VI:Virtual Instance keepalived.conf GLOBAL VRRP LVS ...

  2. DAG最小路径点覆盖

    Problem 给出一个有向无环图 (\(DAG\)),求出最少使用其中多少条互不相交的路径覆盖所有点. Solution 若有 \(n\) 个点,对于每个点 \(i\) ,我们将它拆成两个点 \(i ...

  3. Python: 字典应用题

    Write a program to read through the mbox-short.txt and figure out who has sent the greatest number o ...

  4. 原创:R包制作--windows

    1.下载安装Rtools,添加环境变量: 打开R,分别输入下面指令,看有无包错: system('g++ -v') system('where make') 2.package.skeleton()函 ...

  5. mysql / sqlserver / oracle 常见数据库分页

    空闲时间里用着mysql学习开发测试平台和测试用具, 在公司里将可用的测试平台部署,将数据库换成sqlserver 巴望着能去用oracle的公司 mysql中的分页 limit是mysql的语法se ...

  6. Python3入门 Python3+Selenium做UI页面测试的学习

    https://ke.qq.com/course/310732 一直计划着系统地看看Python3,这两天不用加班了,在网上下了些资源,自己演练一番. Python3标识符保留字,直接命令行中可以查看 ...

  7. Web阶段总结以及感受(附带大一结束暑期学习的纲要)

    之前本人大一因为不是计算机专业的,而又喜欢计算机,所以在大一临时转专业到了计算机院(费劲一番波折),冷笑,还好,从大二开始就可以正式学习喜欢的软件了. 首先,前两天看到一个讲座,提到学习方法,并说出总 ...

  8. 学习笔记38—国外appleID注册教程

    国外appleid注册教程来啦….至于国外appleid有什么用处就不过多的介绍了,需要的人自然是知道,不知道的百度下.1.首先打开苹果appleid注册网址:https://appleid.appl ...

  9. 使用git命令行解决冲突

    文章转载自:https://blog.csdn.net/sureSand/article/details/78765727 使用git和提交的代码有所冲突,用IDE自带的git工具功能多了反而不知道怎 ...

  10. Python学习笔记之参数解析

    python提供了两种方法进行命令行的参数解析,分别是getopt和optparse类中的模块OptionParser,下面分别详细了解这两个模块: 1.getopt模块 首先复习C语言的命令行解析: ...