定义一个名为“ getSecondLargest”的函数,该函数将一个数字(整数)列表作为范围。然后,此函数将识别并返回列表中的第二大数字。 以下是验证规则: 1.如果参数仅包含两个数字,则该函数将返回最小的数字。 2.如果列表仅包含一个数字,则该函数将返回唯一的数字。 3.如果列表为空,或者参数包含任何非整数数据类型,即列表中的字符串或浮点数,则该函数将返回-99000。 请注意,该函数可以接受负整数。 例如: •[1,2,3,4,5,6]返回5 •[6,8,3,4,6]返回6 •[-11,-3,-15,-9,-16]返回-9 •[53,23]返回23 •[13]返回13 •[12,'not number',23]返回-99000 •[]返回-99000
代码这样写,可得到正确结果。
def getSecondLargest(lst):
if lst == [] or any(not isinstance(e, int) for e in lst):
return -99000
if len(lst) == 1:
return lst[0]
else:
second=sorted(lst)[-2]
return second
print(getSecondLargest([1,2,3,4,5,6]))
print(getSecondLargest([6,8,3,4,6]))
print(getSecondLargest([-11, -3, -15, -9, -16]))
print(getSecondLargest([53, 23]))
print(getSecondLargest([13]))
print(getSecondLargest([12, 'not number', 23]))
print(getSecondLargest([]))
#结果
5
6
-9
23
13
-99000
-99000
def getSecondLargest(lst):
if not isinstance(lst, list) or len(lst) == 0 or any(not isinstance(e, int) for e in lst):
return -99000
if len(lst) == 1:
return lst[0]
largest = lst[0]
second = lst[0]
for e in lst:
if e > largest:
second = largest
largest = e
elif e > second:
second = e
return second
print(getSecondLargest([1,2,3,4,5,6]))
print(getSecondLargest([6,8,3,4,6]))
print(getSecondLargest([-11, -3, -15, -9, -16]))
print(getSecondLargest([53, 23]))
print(getSecondLargest([13]))
print(getSecondLargest([12, 'not number', 23]))
print(getSecondLargest([]))
# Output:
5
6
-9
53
13
-99000
-99000
您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632