精通cobol--9.10.3 计算中位数

  所谓中位数,就是一列数据从小到大排列正中间的数据。对于一列数据中的中位数而言,比它大的数和比它小的数应该是一样多的。

这里,若要求取该生所有考试成绩的中位数,仍然可以分两种方法进行。一种是不使用FUNCTION子句,另一种是使用FUNCTION子句。对于不使用FUNCTION子句的方法而言,涉及到较复杂的算法设计,此处不加讨论。

下面,只看使用FUNCTION子句如何完成操作。若使用FUCNTION子句,代码如下。

COMPUTER MID-MARK =

FUNCTION MEDIAN (MARK (ALL)).

这里使用的是FUNCTION子句中的求中位数语句COMPUTER FUNCTION MEDIANMEDIAN在这里代表中位数的意思。对于该语句而言,仍需在数据条目名称MARK后加上“(ALL)”,以表示对全体数据进行计算。

此外,对于前面讲到的二分查找而言,原始数据的编号也可不连续。数据编号不连续的情况,如表所示。

学生成绩表2

SUBJECT-CODE

SUBJECT-NAME

MARK

2

Politics

88

5

Math

93

8

Chinese

86

10

English

78

12

Physics

73

15

Chemistry

75

21

Biology

82

34

Geography

85

SUBJECT-CODE为数据编号,但只是有序排列,并不连续。根据二分查找的方式,需要从表的中间数据项开始查找。此时若要找到表的中间数据,便不能使用类似连续编号情况下的方式进行。否则,若根据通常连续编号情况下的方式进行,将得到以下错误结果。

2+(34-2)/8=6

实际上,对于该表,中间数据编号应该为10或者12(根据具体算法细节不同而不同)。这里用求取中位数的方法便可以很方便地得到正确结果,代码如下。

COMPUTER MID-CODE =

FUNCTION MEDIAN (SUBJECT (ALL)).

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值