描述


http://www.lydsy.com/JudgeOnline/problem.php?id=1588

给出每一天的营业值,求出之前的天当中与它相差最小的营业值与它的差的绝对值(第一天的差值为他本身),求和.

1588: [HNOI2002]营业额统计

Time Limit: 5 Sec  Memory Limit: 162 MB
Submit: 12954  Solved: 4732
[Submit][Status][Discuss]

Description


业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况。
Tiger拿出了公司的账本,账本上记录了公司成立以来每天的营业额。分析营业情况是一项相当复杂的工作。由于节假日,大减价或者是其他情况的时候,营业
额会出现一定的波动,当然一定的波动是能够接受的,但是在某些时候营业额突变得很高或是很低,这就证明公司此时的经营状况出现了问题。经济管理学上定义了
一种最小波动值来衡量这种情况: 该天的最小波动值 当最小波动值越大时,就说明营业情况越不稳定。
而分析整个公司的从成立到现在营业情况是否稳定,只需要把每一天的最小波动值加起来就可以了。你的任务就是编写一个程序帮助Tiger来计算这一个值。
第一天的最小波动值为第一天的营业额。  输入输出要求

Input

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

Output

输出文件仅有一个正整数,即Sigma(每天最小的波动值) 。结果小于2^31 。

Sample Input

6
5
1
2
5
4
6

Sample Output

12

HINT

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

该题数据bug已修复.----2016.5.15

Source

分析


比宠物收养所更裸,果然十几年前的题都是水吗...然而我只会做水题.

注意:

1.第一次写Splay的时候重复的元素直接跳过导致一直T,后来就先把这个值伸展上来再跳过,就过了,果然这种均摊的复杂度不是可以瞎玩的...

另外,不判重似乎慢不了多少...

2.set里写成min(*it-x,x-*(--it))会出错,可能是min函数理由什么奥妙?it多减了几次?...

3.如果set里不先加入INF和-INF的话,每次需要判断*it是不是st.end()(最后一个的后面),st.begin()(第一个).

Treap:

 #include <cstdio>
#include <cstdlib>
#include <algorithm>
using namespace std; const int oo=~0u>>; struct Treap{
struct node{
node* ch[];
int v,r;
node(int v,node* t):v(v){ ch[]=ch[]=t; r=rand(); }
}* root,* null;
Treap(){
null=new node(,NULL); null->r=oo;
root=null;
}
void rot(node* &o,bool d){
node* k=o->ch[!d]; o->ch[!d]=k->ch[d]; k->ch[d]=o;
o=k;
}
void insert(node* &o,int x){
if(o==null) o=new node(x,null);
else{
if(x==o->v) return;
bool d=x>o->v;
insert(o->ch[d],x);
if(o->ch[d]->r<o->r) rot(o,!d);
}
}
int pre(node* o,int x){
if(o==null) return -oo;
if(o->v<=x) return max(pre(o->ch[],x),o->v);
return pre(o->ch[],x);
}
int suc(node* o,int x){
if(o==null) return oo;
if(o->v>=x) return min(suc(o->ch[],x),o->v);
return suc(o->ch[],x);
}
}tree; int n,a,ans; int main(){
scanf("%d",&n);
scanf("%d",&a);
ans+=a; tree.insert(tree.root,a); n--;
while(n--){
if(scanf("%d",&a)==EOF) a=;
int pre=tree.pre(tree.root,a);
int suc=tree.suc(tree.root,a);
if(pre==-oo) ans+=suc-a;
else if(suc==oo) ans+=a-pre;
else ans+=min(suc-a,a-pre);
tree.insert(tree.root,a);
}
printf("%d\n",ans);
return ;
} Treap

Splay:

 #include <cstdio>
#include <algorithm>
using namespace std; const int oo=~0u>>; struct Splay{
struct node{
node* ch[],*pa;
int v;
node(int v,node* t):v(v){ ch[]=ch[]=pa=t; }
bool d(){ return pa->ch[]==this; }
void setc(node* t,bool d) { ch[d]=t; t->pa=this; }
}*root,*null;
Splay(){
null=new node(,NULL);
root=null;
}
void rot(node* o){
node* pa=o->pa; bool d=o->d();
pa->pa->setc(o,pa->d());
pa->setc(o->ch[!d],d);
o->setc(pa,!d);
if(pa==root) root=o;
}
void splay(node* o,node* pa){
while(o->pa!=pa){
if(o->pa->pa==pa) rot(o);
else o->d()==o->pa->d()?(rot(o->pa),rot(o)):(rot(o),rot(o));
}
}
void insert(int x){
if(root==null){ root=new node(x,null); return; }
node* t=root;
if(t->v==x) return;
while(t->ch[x>t->v]!=null&&t->ch[x>t->v]->v!=x) t=t->ch[x>t->v];
if(t->ch[x>t->v]!=null){ splay(t->ch[x>t->v],null); return; }
node* k=new node(x,null);
t->setc(k,x>t->v);
splay(k,null);
}
int pre(int x){
node* t=root;
int ret=-oo;
while(t!=null){
if(t->v==x) return x;
if(t->v<x) ret=t->v,t=t->ch[];
else t=t->ch[];
}
return ret;
}
int suc(int x){
node* t=root;
int ret=-oo;
while(t!=null){
if(t->v==x) return x;
if(t->v>x) ret=t->v,t=t->ch[];
else t=t->ch[];
}
return ret;
}
}tree; int n,a,ans; int main(){
scanf("%d",&n);
scanf("%d",&a);
ans+=a; tree.insert(a); n--;
while(n--){
if(scanf("%d",&a)==EOF) a=;
int pre=tree.pre(a);
int suc=tree.suc(a);
if(pre==-oo) ans+=suc-a;
else if(suc==-oo) ans+=a-pre;
else ans+=min(suc-a,a-pre);
tree.insert(a);
}
printf("%d\n",ans);
return ;
}

set:

 #include <bits/stdc++.h>
using namespace std; const int INF=0x3fffffff;
int n,x,ans;
set <int> st;
int main(){
scanf("%d",&n);
st.insert(INF); st.insert(-INF);
scanf("%d",&x); ans=x; st.insert(x);
set <int> :: iterator it;
for(int i=;i<n;i++){
scanf("%d",&x);
it=st.lower_bound(x);
int a=*it-x,b=x-*(--it);
int ret=min(a,b);
if(ret) ans+=ret, st.insert(x);
}
printf("%d\n",ans);
return ;
}

BZOJ_1588_&_Codevs_1296_[HNOI2002]_营业额统计(平衡树/set)的更多相关文章

  1. 「HNOI2002」营业额统计

    「HNOI2002」营业额统计 传送门 这题比较板子吧应该... 有几个需要注意的地方: 第一次插入时就要贡献答案 在每次计算贡献时,注意分裂出来的子树是否为空,并且要对两边的相邻元素之差取 \(\m ...

  2. 【HNOI2002】营业额统计

    https://www.luogu.org/problem/show?pid=2234 用Treap维护,每次查询这个数的前驱与后继哪个和它差值更小. 由于查询一个数时在Treap走出的路径必定经过它 ...

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

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

  4. 1588. [HNOI2002]营业额统计【平衡树-splay 或 线段树】

    Description 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况. Tiger拿出了公司的账本,账本上记录了公司成立以来每 ...

  5. B1588 [HNOI2002]营业额统计 set||平衡树

    平衡树题,求每个点的前驱,照例可以用set水过...(平衡树还是不会写) 又新学了一个用法: set <int> ::iterator s1; 这样s1就可以直接附为set中的地址了.但是 ...

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

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

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

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

  8. [HNOI2002]营业额统计_Treap

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

  9. 2018.07.06 BZOJ 1588: HNOI2002营业额统计(非旋treap)

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MB Description 营业额统计 Tiger最近被公司升任为营业部经理,他上 ...

随机推荐

  1. MVC小系列(八)【改变Areas的FindView顺序】

    MVC小系列(八)[改变Areas的FindView顺序] 一般项目比较大的话,会根据模块建立Areas,这样结构清晰,也有利于路由的部署, 1 Areas下有自己的_LayOut模板,而如果希望所有 ...

  2. c语言学习之基础知识点介绍(十三):枚举的介绍和使用

    一.枚举的介绍 /* 枚举:限制的待选项. 语法: enum 枚举名{ 选项1, 选项2, 选项3, ........ 选项n }; 注意:枚举中,选项之间用 , 隔开,最后一个不用加 , :并且枚举 ...

  3. PHP学习笔记(八)

    关于PHP中的缓存函数ob_start() and ob_end_flush(). PHP输出机制:输出内容->缓存->输出到浏览器.ob_start(callback function) ...

  4. fastjson的坑 com.alibaba.fastjson.JSONObject cannot be cast to xxx

    解析json对象时,使用了new TypeReference()对象 fastjson会对解析的对象类型进行缓存   new TypeReference<ResultData>(){}   ...

  5. Android WebRTC视频旋转问题

    最近在对接WebRTC到安卓手机上,有个需求就是手机横屏时将对方图像进行旋转,研究了WebRTC video_render的代码后发现远端的视频渲染使用opengles20或surfaceview实现 ...

  6. (转) IOS用CGContextRef画各种图形(文字、圆、直线、弧线、矩形、扇形、椭圆、三角形、圆角矩形、贝塞尔曲线、图片)

    首先了解一下CGContextRef: An opaque type that represents a Quartz 2D drawing environment. Graphics Context ...

  7. win7下简单FTP服务器搭建

    本文介绍通过win7自带的IIS来搭建一个只能实现基本功能的FTP服务器,第一次装好WIN7后我愣是没整出来,后来查了一下网上资料经过试验后搭建成功,其实原理和步骤与windows前期的版本差不多,主 ...

  8. MyEclipse 搭建webservice (axis1.4)

    0 引言  以前都是做javaweb的 最近因工作需要 接触了webservice 关于什么事webservice,与web的区别,soap,跟http的区别,asix1和asix2的区别,为什么不用 ...

  9. sql 自身连接

    "select table1.field1, table2.field1 from table table1, table table2 where table1.id=table2.par ...

  10. mongodb数据库操作--备份 还原 导出 导入

    首先数据库备份: mongodump -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -o 文件存在路径  mongodump -h 127.0.0.1 -u admin -p ...