BZOJ_1588_&_Codevs_1296_[HNOI2002]_营业额统计(平衡树/set)
描述
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
5
1
2
5
4
6
Sample Output
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)的更多相关文章
- 「HNOI2002」营业额统计
「HNOI2002」营业额统计 传送门 这题比较板子吧应该... 有几个需要注意的地方: 第一次插入时就要贡献答案 在每次计算贡献时,注意分裂出来的子树是否为空,并且要对两边的相邻元素之差取 \(\m ...
- 【HNOI2002】营业额统计
https://www.luogu.org/problem/show?pid=2234 用Treap维护,每次查询这个数的前驱与后继哪个和它差值更小. 由于查询一个数时在Treap走出的路径必定经过它 ...
- 数据结构:(平衡树,链表)BZOJ 1588[HNOI2002]营业额统计
1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 12173 Solved: 4354[Submit][Sta ...
- 1588. [HNOI2002]营业额统计【平衡树-splay 或 线段树】
Description 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况. Tiger拿出了公司的账本,账本上记录了公司成立以来每 ...
- B1588 [HNOI2002]营业额统计 set||平衡树
平衡树题,求每个点的前驱,照例可以用set水过...(平衡树还是不会写) 又新学了一个用法: set <int> ::iterator s1; 这样s1就可以直接附为set中的地址了.但是 ...
- 1588: [HNOI2002]营业额统计
1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 9203 Solved: 3097[Submit][Stat ...
- 【链表】BZOJ1588: [HNOI2002]营业额统计
1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 17555 Solved: 7179[Submit][Sta ...
- [HNOI2002]营业额统计_Treap
[HNOI2002]营业额统计 题目大意:给你一串n数序列,对于每一个刚输入的数a,找到一个前面的数k,使得|a-k|最小. 注释:$n<=32767,ai<=10^6$. 想法:刚学Tr ...
- 2018.07.06 BZOJ 1588: HNOI2002营业额统计(非旋treap)
1588: [HNOI2002]营业额统计 Time Limit: 5 Sec Memory Limit: 162 MB Description 营业额统计 Tiger最近被公司升任为营业部经理,他上 ...
随机推荐
- SqlServer Change Data Capture(CDC)数据变更捕获
最近在使用SqlServer2008r2数据库做系统的时候,在某些重要的.经常涉及到修改的表上,想加上一些恢复机制,一开始想找找看看有没有类似Oracle数据库闪回那样的功能,后来发现CDC的功能可以 ...
- MVC小系列(十二)【RenderAction和RenderPartial区别】
二者作用:RenderAction:渲染分部视图到页面上,要求提供Action和控制器名称RenderPartial:渲染分部视图到页面上,要求提供分部视图的名称,即路径,如果是在当前控制下或者sha ...
- iOS测试一段代码的运行时间
王刚韧 23:19:26测试一段代码的运行时间 测试一段代码运行花了多久: NSDate* tmpStartData = [NSDate date] ;<#代码#> double delt ...
- Codevs 1690 开关灯 USACO
1690 开关灯 USACO 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description YYX家门前的街上有N(2<=N& ...
- HttpClient4.3 使用经验(一) 简单使用
package com.wp.nevel.base.utils; import java.io.BufferedOutputStream; import java.io.BufferedReader; ...
- Github进行项目管理的常用命令总结
最近项目中使用github来管理代码,将git的常用命令整理了一下,方便以后查询 查看git的本地配置git config --list 克隆到本地git clone (网页上面的那个http地址 g ...
- ubuntu vim 插件安装
参考:http://blog.sina.com.cn/s/blog_00f0230d0100y7ih.html 不过由于时间久远,有些已经失效,以上是我的修改过程 参考:https://github. ...
- 【Android】Sqlite3命令详解
Sqlite3常用命令 Sqlite3命令有"."符合作为前缀. 基本操作 1.创建或者打开数据库 sqlite3 xxx.db 如果xxx.db存在则打开如果没有则新建此时执行创 ...
- 如何在Html的div+css中去除<li>标签前面小黑点,和ul、LI部分属性方法
div是很多人做网站都会用到的,但在显示效果时前面总是会有一个小黑点,这个效果很多人不想要,但又不知到如何去除,然而我们可以用以下方法来清除. 1.在CSS中写入代码.找到相关性的CSS,在..li和 ...
- C# Thread多线程学习
自我学习理解:一个程序中包括多个进程,每个进程包括多个线程,多个线程可同时做不同的事情(说是同时,但它是交换执行的,人感觉像是同时罢了). 优点:提高CPU的使用率. 线程同步:同步就是指一个线程要等 ...