(python3)1054.求平均值 (20分)

题目叙述如下:

本题的基本要求非常简单:给定N个实数,计算它们的平均值。但复杂的是有些输入数据可能是非法的。一个“合法”的输入是[-1000,1000]区间内的实数,并且最多精确到小数点后2位。当你计算平均值的时候,不能把那些非法的数据算在内。

输入格式:
输入第一行给出正整数N(<=100)。随后一行给出N个实数,数字间以一个空格分隔。
输出格式:
对每个非法输入,在一行中输出“ERROR: X is not a legal number”,其中X是输入。最后在一行中输出结果:“The average of K numbers is Y”,其中K是合法输入的个数,Y是它们的平均值,精确到小数点后2位。如果平均值无法计算,则用“Undefined”替换Y。如果K为1,则输出“The average of 1 number is Y”。
输入样例1:
7
5 -3.2 aaa 9999 2.3.4 7.123 2.35
输出样例1:
ERROR: aaa is not a legal number
ERROR: 9999 is not a legal number
ERROR: 2.3.4 is not a legal number
ERROR: 7.123 is not a legal number
The average of 3 numbers is 1.38
输入样例2:
2
aaa -9999
输出样例2:
ERROR: aaa is not a legal number
ERROR: -9999 is not a legal number

The average of 0 numbers is Undefined

题目解析:

像这种要求简单的题目,往往比较坑,陷阱比较多,现在我们详细解析一下。

正整数N我们可以不要,我们需要得到第二行的那一串东西,切分成列表;然后就是遍历列表,合法的去算平均数,不合法的输出指定信息;最后再根据不同的k(合法的数目)输出不同的结果。其他部分自己看一下就好了,关键都在于判断合法数的过程!

该部分有不同的实现思路,可以当作字符串挨个字符判断,比如第一位或者是负号‘-’或者是数字;鄙人通过正则表达式,江所有合法的情况匹配出来,match对象不为None即匹配成功。

从鄙人的正则式子可以看到题目存在的几个陷阱,详细的可看代码

1)诸如“.12”这样的没有整数位的(貌似测试点不包含),"12."这样的只有个小数点的,都可以接受,所以匹配的数字都是{0,3},{0,2}

2)诸如 "002" 这样的数也是合法的,因此鄙人没有设定整数部分最高位不为0的规则; 大坑

3)边界条件 (-)1000要注意带小数部分的情况(最后一个测试点),即1000.00之类的;

import re
# 输入
n = input()
num_lst = input().strip().split()
# 主要函数
def check(num):
    pat = r'^[-]?(\d{0,3}|1000)$|^[-]?\d{0,3}\.[0-9]{0,2}$|^[-]?1000\.0{0,2}$'
    m = re.match(pat, num)
    return True if m else False
# 遍历处理
k, sum_num = 0, 0.0
for num in num_lst:
    flag = check(num)
    if flag:
        k += 1
        sum_num += float(num)
    else:
        print("ERROR: %s is not a legal number" % num)

# 输出控制
if k == 0:
    print("The average of 0 numbers is Undefined")
elif k == 1:
    print("The average of 1 number is %.2f" % sum_num)
else:
    print("The average of %d numbers is %.2f" % (k, sum_num/k))

你可能感兴趣的:(Python3之PAT乙级)