如何在排序列表中获取最大和最小的数字?

时间:2013-11-05 18:25:45

标签: python list sorting python-3.3

def list_stats(values, num_int, low_range, high_range):  # function to fix
    values = generate_integer_list(num_int, low_range, high_range)
    new_val = values.sort()
    low_val = new_val[0]
    high_val = new_val[num_int - 1]
    total = 0
    i = 0
    for num in range(num_int-1):
        i = i + 1
        num = values[i]
        total = total + num
    avg = total/num_int
    return total, low_val, high_val, avg


def generate_integer_list(num_int, low_range, high_range): # generates random #'s
    values = []
    for count in range(num_int):
        number = random.randint(low_range, high_range)
        values.append(number)
    return values

我必须在生成的列表中找到最大和最小的数字,得到列表中所有数字的总和和平均值。我的号码由generate_integer_list生成。

我已经使用sort函数对生成的列表进行排序,然后获取该列表中最小和最大的第一个和最后一个数字。但是,返回的值无论如何都不正确。我尝试给排序列表一个新名称,但这不起作用。

我可以返回正确值的唯一方法是,如果我打印排序列表,但我不允许对问题这样做。我该如何解决这个问题?

2 个答案:

答案 0 :(得分:2)

您计算总跳过第一个值的代码;只需直接遍历数字列表 ,无需在此处创建范围:

total = 0
for num in values:
    total = total + num

你可以这样做而不需要分拣;你必须遍历所有数字:

def list_stats(values, num_int, low_range, high_range):
    values = generate_integer_list(num_int, low_range, high_range)
    total = 0
    low_val = high_val = values[0]  # something to start with
    for num in values:
        total += num
        if num < low_val:
            low_val = num
        if num > high_val:
            high_val = num
    avg = total / num_int
    return total, low_val, high_val, avg

我将total = total + num替换为total += num,因为它与数字相同。

我还使用值列表中的第一个值启动了low_valhigh_val;然后,循环将随之发现任何更低或更高的值。

答案 1 :(得分:1)

如果这是您选择的方向,可以使用几个BIF来简化此操作。

sum(numlist) # the sum of your random list
sum(numlist) / len(numlist) # average your list
sorted(numlist, key=int)[0] # lowest element
numlist[len(numlist) - 1] # list is already sorted this gives you the max

快速片段;我没有重写你的代码。