-7

给定一个 Python 列表,计算并返回第二大数和第二小数之间的差。假设列表包含两个或更多元素。功能说明:第二大/最小必须不同于列表中的最大/最小数字。那是:

difference([10, 10, 10, 8, 5, 2, 1, 1, 1]) == 8 - 2 == 6

应该将列表作为输入。

def difference(list1):

    # Your code here

    return* 
4

2 回答 2

1

首先,我们从给定的列表中构造一个集合以删除重复值,然后对它们进行排序以轻松找到第二高和第二小的值。

def difference(list1):
    list1 = sorted(set(list1))
    print(list1) # --> [1, 2, 5, 8, 10]

    if list1[1] != list1[-2]:
        return list1[-2] - list1[1]

print(difference([10, 10, 10, 8, 5, 2, 1, 1, 1]) == 8 - 2 == 6) # --> True
于 2019-04-08T09:33:24.483 回答
0

这是一个简单但不是最有效的方法。您可以通过两步来实现:

  1. 转换listset, 以删除重复的数字。
  2. 用于heap查找nlargestnsmallest输入set
def difference(list1):
    set1 = set(list1)
    return heapq.nlargest(2, set1)[1] - heapq.nsmallest(2, set1)[1]

这是一种一次性的方式,更有效的方式,使用 4 个变量:

def difference(list1):
    max1, max2, min1, min2 = float('-inf'), float('-inf'), float('inf'), float('inf')
    for x in list1:
        if x > max1:
            max1, max2 = x, max1
        elif x >= max2 and x != max1:
            max2 = x

        if x < min1:
            min1, min2 = x, min1
        elif x <= min2 and x != min1:
            min2 = x

    return max2 - min2

测试和输出:

print(difference([10, 10, 10, 8, 5, 2, 1, 1, 1]))
# 6

希望对您有所帮助,如果您还有其他问题,请发表评论。:)

于 2019-04-08T09:32:37.707 回答