AC日记——营业额统计 1296 codevs
Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况。
Tiger拿出了公司的账本,账本上记录了公司成立以来每天的营业额。分析营业情况是一项相当复杂的工作。由于节假日,大减价或者是其他情况的时候,营业额会出现一定的波动,当然一定的波动是能够接受的,但是在某些时候营业额突变得很高或是很低,这就证明公司此时的经营状况出现了问题。经济管理学上定义了一种最小波动值来衡量这种情况:
该天的最小波动值 = min{|该天以前某一天的营业额-该天营业额|}
当最小波动值越大时,就说明营业情况越不稳定。
而分析整个公司的从成立到现在营业情况是否稳定,只需要把每一天的最小波动值加起来就可以了。你的任务就是编写一个程序帮助Tiger来计算这一个值。
第一天的最小波动值为第一天的营业额。
第一行为正整数n(n<=32767),表示该公司从成立一直到现在的天数,接下来的n行每行有一个正整数ai(ai<=1000000),表示第i天公司的营业额。
输出文件仅有一个正整数,即每天最小波动值之和,小于231
6
5
1
2
5
4
6
12
结果说明:5+|1-5|+|2-1|+|5-5|+|4-5|+|6-5|=5+4+1+0+1+1=12
思路:
裸treap模板;
支持插入,寻找前驱、后继操作;
每次插入一个点
然后寻找这个点的前驱和后继,比较哪个的波动小然后累加
来,上代码:
#include <cstdio>
#include <cstdlib>
#include <iostream>
#include <algorithm> using namespace std; struct TreeNode {
int key,fix,weight,size; TreeNode *left,*right;
}; class TreapType {
private:
TreeNode *null,*root,*start; int n,if_z,pos,ans; char Cget; inline void read_int(int &now)
{
now=,if_z=,Cget=getchar();
while(Cget>''||Cget<'')
{
if(Cget=='-') if_z=-;
Cget=getchar();
}
while(Cget>=''&&Cget<='')
{
now=now*+Cget-'';
Cget=getchar();
}
now*=if_z;
} public:
TreapType()
{
null=new TreeNode;
null->left=null;
null->right=null;
root=null;
start=new TreeNode;
start->key=0x7ffffff;
start->left=null;
start->right=null;
read_int(n);
read_int(pos);
ans+=abs(pos);
Insert(root,pos);
for(int i=;i<=n;i++)
{
read_int(pos);
Insert(root,pos);
int pre=Predecessor(root,pos,start);
int suc=Successor(root,pos,start);
ans+=min(abs(pre-pos),abs(suc-pos));
}
printf("%d\n",ans);
} void Rotato_Left(TreeNode *&now)
{
TreeNode *tmp=now->right;
now->right=tmp->left;
tmp->left=now;
now=tmp;
now->left->size=now->left->left->size+now->left->weight+now->left->right->size;
now->size=now->left->size+now->right->size+now->weight;
} void Rotato_Right(TreeNode *&now)
{
TreeNode *tmp=now->left;
now->left=tmp->right;
tmp->right=now;
now=tmp;
now->right->size=now->right->left->size+now->right->weight+now->right->left->size;
now->size=now->left->size+now->weight+now->right->size;
} void Insert(TreeNode *&now,int key)
{
if(now==null)
{
now=new TreeNode;
now->fix=rand();
now->key=key;
now->left=null;
now->right=null;
now->size=;
now->weight=;
return ;
}
if(now->key==key)
{
now->weight++;
}
else if(now->key<key)
{
Insert(now->right,key);
if(now->right->fix>now->fix) Rotato_Left(now);
}
else if(now->key>key)
{
Insert(now->left,key);
if(now->left->fix>now->fix) Rotato_Right(now);
}
now->size=now->left->size+now->right->size+now->weight;
} int Predecessor(TreeNode *&now,int key,TreeNode *&optimal)
{
if(now==null) return optimal->key;
if(now->key==key)
{
if(now->weight>) return key;
else return Predecessor(now->left,key,optimal);
}
else
{
if(now->key<key) return Predecessor(now->right,key,now);
else return Predecessor(now->left,key,optimal);
}
} int Successor(TreeNode *&now,int key,TreeNode *&optimal)
{
if(now==null) return optimal->key;
if(now->key==key)
{
if(now->weight>) return key;
else return Successor(now->right,key,optimal);
}
else
{
if(now->key>key) return Successor(now->left,key,now);
else return Successor(now->right,key,optimal);
}
}
};
class TreapType do_; int main()
{
return ;
}
AC日记——营业额统计 1296 codevs的更多相关文章
- AC日记——营业额统计 codevs 1296 (splay版)
营业额统计 思路: 每次,插入一个点: 然后找前驱后继: 来,上代码: #include <cmath> #include <cstdio> #include <iost ...
- AC日记——接龙游戏 codevs 1051
1051 接龙游戏 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 给出了N个单词,已经按长度排好了序.如果 ...
- AC日记——数字统计 openjudge 1.5 41
41:数字统计 总时间限制: 1000ms 内存限制: 65536kB 描述 请统计某个给定范围[L, R]的所有整数中,数字2出现的次数. 比如给定范围[2, 22],数字2在数2中出现了1次, ...
- AC日记——最优贸易 codevs 1173
题目描述 Description [问题描述]C 国有n 个大城市和m 条道路,每条道路连接这n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这m 条道路中有一部分为单向通行的道路 ...
- AC日记——地鼠游戏 codevs 1052
1052 地鼠游戏 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 王钢是一名学习成绩优异的学生,在平 ...
- AC日记——鬼谷子的钱袋 codevs 2998
2998 鬼谷子的钱袋 2006年省队选拔赛湖南 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 鬼谷子非常聪明,正 ...
- AC日记——舒适的路线 codevs 1001 (并查集+乱搞)
1001 舒适的路线 2006年 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description Z小镇是 ...
- AC日记——逃跑的拉尔夫 codevs 1026 (搜索)
1026 逃跑的拉尔夫 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 年轻的拉尔夫开玩笑地从一 ...
- AC日记——自然数和分解 codevs 2549
自然数和分解 思路: 水题: 代码: #include <bits/stdc++.h> using namespace std; ][]; int main() { cin>> ...
随机推荐
- for循环+canvas实现黑客帝国矩形阵
<!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content=& ...
- TCP/IP网络编程之基于TCP的服务端/客户端(二)
回声客户端问题 上一章TCP/IP网络编程之基于TCP的服务端/客户端(一)中,我们解释了回声客户端所存在的问题,那么单单是客户端的问题,服务端没有任何问题?是的,服务端没有问题,现在先让我们回顾下服 ...
- datagrid的toolbar的两种实现方式
datagrid的toolbar的两种实现方式 1.在html文件中,可以在设置toolbar="#tb",再在div中设置id="tb" <table ...
- Nodejs-文件流
1.什么是流? 流是程序输入输出的一个连续的字节序列. 有文件流,网络流,设备(例如鼠标,键盘,磁盘,调制解调器和打印机)的输入输出都是用流来处理的. 任何数据的最根本表现形式都是二进制. 读取文件 ...
- Python框架之Django学习笔记(八)
模板继承 到目前为止,我们的模板范例都只是些零星的 HTML 片段,但在实际应用中,你将用 Django 模板系统来创建整个 HTML 页面. 这就带来一个常见的 Web 开发问题: 在整个网站中,如 ...
- python学习-- django 2.1.7 ajax 请求 进阶版
#原来版本 $.get("/add/",{'a':a,'b':b}, function(ret){ $('#result').html(ret)}) #进阶版 $.get(&qu ...
- 前端应该掌握的CSS实现多列等高布局
1.引言 我们在写页面的时候,有的时候会遇到多栏布局,每个栏目里面的内容有的时候可能不一样,这样就会导致每个栏目实际的高度也是不一样的,如果每个栏目有背景颜色的,就会导致每个栏目的底部是对不齐的,用户 ...
- 【LeetCode】Merge Two Sorted Lists(合并两个有序链表)
这道题是LeetCode里的第21道题. 题目描述: 将两个有序链表合并为一个新的有序链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的. 示例: 输入:1->2->4, 1-&g ...
- Windows 7中安装SQL2005提示IIS未安装 解决办法 .(转载)
在Windows 7系统中安装SQL Server 2005时,可能会收到一个警告:提示IIS未安装或者未启用.在通过“控制面板”的“打开或关闭Windows功能”按默认设置安装IIS后,发现仍有这个 ...
- 【bzoj1146】[CTSC2008]网络管理Network 倍增LCA+dfs序+树状数组+主席树
题目描述 M公司是一个非常庞大的跨国公司,在许多国家都设有它的下属分支机构或部门.为了让分布在世界各地的N个部门之间协同工作,公司搭建了一个连接整个公司的通信网络.该网络的结构由N个路由器和N-1条高 ...