首页 > 其他 > 详细

题解:HNOI2002 营业额统计

时间:2018-09-11 22:24:25      阅读:168      评论:0      收藏:0      [点我收藏+]

题目描述

Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况。

Tiger拿出了公司的账本,账本上记录了公司成立以来每天的营业额。分析营业情况是一项相当复杂的工作。由于节假日,大减价或者是其他情况的时候,营业额会出现一定的波动,当然一定的波动是能够接受的,但是在某些时候营业额突变得很高或是很低,这就证明公司此时的经营状况出现了问题。经济管理学上定义了一种最小波动值来衡量这种情况:

当最小波动值越大时,就说明营业情况越不稳定。

而分析整个公司的从成立到现在营业情况是否稳定,只需要把每一天的最小波动值加起来就可以了。你的任务就是编写一个程序帮助Tiger来计算这一个值。

第一天的最小波动值为第一天的营业额。

该天的最小波动值=min{|该天以前某一天的营业额-该天营业额|}。

 

解题思路:

 

这道题可以用离线链表解决,先一次性读到最后一个,再根据读入的顺序删除加进来的高度

 

 

 1var
2    answer,height,previous,next:array[0..40005of longint;
3    rank:array[0..40005of longint;
4    n,higher,shorter,i,maxn,sum:longint;
5procedure sort(l,r:longint);
6var
7    x,i,j,tmp:longint;
8begin
9    x:=height[rank[(l+r) div 2]];i:=l;j:=r;
10    while i<=j do
11    begin
12        while height[rank[i]] < x do
13            inc(i);
14        while height[rank[j]] > x do
15            dec(j);
16        if  i<=j then
17        begin
18            //swap(rank[i],rank[j]);
19            tmp:=rank[i];
20            rank[i]:=rank[j];
21            rank[j]:=tmp;
22            inc(i); dec(j);
23        end;
24    end;
25    if i<r then sort(i,r);
26    if l<j then sort(l,j);
27end;
28begin
29    maxn:=40005;
30    readln(n);
31    for i:=1 to n do
32    begin
33        read(height[i]);
34        rank[i]:=i;
35    end;
36    sort(1,n);
37    for i:=1 to n do
38    begin
39        previous[rank[i]]:=rank[i-1];
40        next[rank[i]]:=rank[i+1];
41    end;
42    for i:=n downto 2 do
43    begin
44        higher:=1023456789; shorter:=1023456789;
45        if previous[i]<>0 then
46            shorter:=height[i] - height[previous[i]];
47        if next[i]<>0 then
48            higher:=height[next[i]]-height[i];
49        if shorter < higher then
50            answer[i]:=previous[i] else
51            answer[i]:=next[i];
52        next[previous[i]]:=next[i];
53        previous[next[i]]:=previous[i];
54    end;
55    sum:=height[1];
56    for i:=2 to n do
57        sum:=sum+(abs(height[i]-height[answer[i]]));
58    //    sum:=sum+answer[i];
59    //writeln(sum);
60    writeln(sum);
61end.

题解:HNOI2002 营业额统计

原文:https://www.cnblogs.com/titititing/p/9630675.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!