给定一个 Python 列表,计算并返回第二大数和第二小数之间的差。假设列表包含两个或更多元素。功能说明:第二大/最小必须不同于列表中的最大/最小数字。那是:
difference([10, 10, 10, 8, 5, 2, 1, 1, 1]) == 8 - 2 == 6
应该将列表作为输入。
def difference(list1):
# Your code here
return*
给定一个 Python 列表,计算并返回第二大数和第二小数之间的差。假设列表包含两个或更多元素。功能说明:第二大/最小必须不同于列表中的最大/最小数字。那是:
difference([10, 10, 10, 8, 5, 2, 1, 1, 1]) == 8 - 2 == 6
应该将列表作为输入。
def difference(list1):
# Your code here
return*
首先,我们从给定的列表中构造一个集合以删除重复值,然后对它们进行排序以轻松找到第二高和第二小的值。
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
这是一个简单但不是最有效的方法。您可以通过两步来实现:
list
为set
, 以删除重复的数字。heap
查找nlargest
和nsmallest
输入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
希望对您有所帮助,如果您还有其他问题,请发表评论。:)