定义一个名为“ getSecondLargest”的函数,该函数将一个数字(整数)列表作为 范围。然后,此函数将识别并返回列表中的第二大数字。 以下是验证规则: 1.如果参数仅包含两个数字,则该函数将返回最小的数字。 2.如果列表仅包含一个数字,则该函数将返回唯一的数字。 3.如果列表为空,或者参数包含任何非整数数据类型,即列表中的字符串或浮点数,则该函数将返回-99000。 请注意,该函数可以接受负整数。
def getSecondLargest(li):
if type(li)!=list or len(li)==0 or any(map(lambda x: type(x)!=int, li)):
return -99000
if len(li)==1:
return li[0]
li.remove(max(li))
return max(li)
if __name__ == "__main__":
print(getSecondLargest([-8,-7,-5,8])) #输出-5
print(getSecondLargest([8])) #输出8
print(getSecondLargest([])) #输出-99000
print(getSecondLargest([-8,-7,-5,8.6])) #输出-99000
print(getSecondLargest(9)) #输出-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))
print(getSecondLargest([]))
print(getSecondLargest([1]))
print(getSecondLargest([1, 2, 3.0]))
print(getSecondLargest([2, 1, 3]))
print(getSecondLargest([2, 1, 3, 9, 8, 7, 6, -100, -2, -4]))
# Output:
-99000
-99000
1
-99000
2
8
您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632