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
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
双向链表~
不能再裸的裸题~
我好像做麻烦了,排了两次序,记录左右值,然后从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;
}