题目描述

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. Mysql 函数使用记录(一)——DATEDIFF、CONCAT

    当目前为止呢,个人对Mysql的函数没有进行过统一的学习使用,都是用到了再去学习.而近日开始学习Linux了,所以为了防止这段时期结束后,将此阶段期间遇到的Mysql函数遗忘,开始在此对其做一个简单的 ...

  3. bzoj 1036: [ZJOI2008]树的统计Count 树链剖分+线段树

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 16294  Solved: 6645[Submit ...

  4. Java java.lang.SecurityException: Prohibited package name

    java.lang.SecurityException: Prohibited package name 提示java错误: Exception in thread "main" ...

  5. Codeforces 458C - Elections

    458C - Elections 思路: 三分凹形函数极小值域 代码: #include<bits/stdc++.h> using namespace std; #define ll lo ...

  6. Eclipse无法使用springboot2.x

    <!-- 阿里云提供的镜像地址 --> <mirror> <id>nexus-aliyun</id> <mirrorOf>*</mir ...

  7. Redis的安装及命令返回值

    Linux下安装Reids : http://redis.io/download 下载最新稳定版本 wget http://download.redis.io/releases/redis-3.0.7 ...

  8. 理解css相邻兄弟选择器

    今天在菜鸟教程看到了css组合选择符的“相邻兄弟选择器”,刚开始对这个概念有些不太理解,通过查阅资料并且经过一些试验总算有了些头绪. 原文解释是“相邻兄弟选择器(Adjacent sibling se ...

  9. Spring之Spel表达式

    正常业务场景一般不用这个技术,但需要知道有这么个东西支持Spring. 记忆力不好,抄了些套路代码便于以后用到. package com.paic.phssp.springtest.spel; imp ...

  10. 雷林鹏分享:jQuery EasyUI 数据网格 - 创建子网格

    jQuery EasyUI 数据网格 - 创建子网格 使用数据网格(datagrid)的详细视图,用户可以展开一行来显示附加的详细信息. 任何内容都可以加载作为行详细,子网格也可以动态加载. 本教程将 ...