BZOJ 1588 [HNOI2002] 营业额统计
来源:互联网 发布:淘宝达人大v认证范文 编辑:程序博客网 时间:2024/06/06 00:36
Description
营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况。 Tiger拿出了公司的账本,账本上记录了公司成立以来每天的营业额。分析营业情况是一项相当复杂的工作。由于节假日,大减价或者是其他情况的时候,营业额会出现一定的波动,当然一定的波动是能够接受的,但是在某些时候营业额突变得很高或是很低,这就证明公司此时的经营状况出现了问题。经济管理学上定义了一种最小波动值来衡量这种情况: 该天的最小波动值 当最小波动值越大时,就说明营业情况越不稳定。 而分析整个公司的从成立到现在营业情况是否稳定,只需要把每一天的最小波动值加起来就可以了。你的任务就是编写一个程序帮助Tiger来计算这一个值。 第一天的最小波动值为第一天的营业额。 输入输出要求
Input
第一行为正整数 ,表示该公司从成立一直到现在的天数,接下来的n行每行有一个整数(有可能有负数) ,表示第i天公司的营业额。
Output
输出文件仅有一个正整数,即Sigma(每天最小的波动值) 。结果小于2^31 。
Sample Input
6
5
1
2
5
4
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
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
双向链表~
不能再裸的裸题~
我好像做麻烦了,排了两次序,记录左右值,然后从n计算到2,1单独加。
#include<cstdio>#include<iostream>#include<algorithm>#include<cmath>using namespace std;int n,x,le[100001],ri[100001],ans;struct node{int num,val;}a[100002];bool cmp1(node u,node v){return u.val<v.val;}bool cmp2(node u,node v){return u.num<v.num;}int main(){scanf("%d",&n);for(int i=1;i<=n;i++){scanf("%d",&a[i].val);a[i].num=i;}sort(a+1,a+n+1,cmp1);for(int i=1;i<=n;i++){le[a[i].num]=a[i-1].num;ri[a[i].num]=a[i+1].num;}sort(a+1,a+n+1,cmp2);for(int i=n;i>=2;i--){int minn=999999999;if(le[i]>0) minn=min(minn,abs(a[le[i]].val-a[i].val));if(ri[i]>0) minn=min(minn,abs(a[ri[i]].val-a[i].val));ri[le[i]]=ri[i];le[ri[i]]=le[i];ans+=minn;}ans+=a[1].val;printf("%d\n",ans);return 0;}
1 0
- BZOJ 1588 [HNOI2002] 营业额统计
- BZOJ 1588 [HNOI2002]营业额统计
- bzoj 1588 [HNOI2002] 营业额统计
- BZOJ 1588: [HNOI2002]营业额统计
- BZOJ 1588 [HNOI2002]营业额统计
- BZOJ 1588: [HNOI2002] 营业额统计
- BZOJ 1588 营业额统计【HNOI2002】
- [BZOJ 1588][HNOI2002]营业额统计
- bzoj 1588 [HNOI2002]营业额统计
- bzoj 1588 [HNOI2002]营业额统计
- BZOJ 1588: [HNOI2002]营业额统计
- bzoj 1588 [HNOI2002]营业额统计
- BZOJ 1588 [HNOI2002] 营业额统计
- BZOJ 1588:[HNOI2002]营业额统计
- BZOJ 1588 [HNOI2002]营业额统计
- 【HNOI2002】【BZOJ 1588】营业额统计
- 【HNOI2002】【BZOJ 1588】营业额统计
- BZOJ 1588 [HNOI2002] 营业额统计
- Unable to start the daemon process--Could not reserve enough space for object heap
- 快来使用HTTPS吧
- hdu1069 Monkey and Banana(二维LIS)
- python 操作outlook
- 在未提供官方驱动的Windows平板上安装Win10且完美驱动的解决方案
- BZOJ 1588 [HNOI2002] 营业额统计
- linux系统安装mysql数据库过程解析
- struts2配置
- java 身份证验证题
- PPT生成PNG---解决中文乱码和字体大小、位置偏移等问题
- 单选,全选,反选简单Demo
- 今天来说说html5的拖拽
- Android中ListView的定位
- 水池数目