使用迭代查找一个list中最小和最大值,并返回一个tuple

#"请使用迭代查找一个list中最小和最大值,并返回一个tuple: "
def findMinAndMax(list):
    if len(list)==0:
        return (None, None)
    minVal = list[0]
    maxval = list[0]
    for x in list:
        if(x>maxval):
            maxval=x
        if(x<minVal):
            minVal=x
    return (minVal,maxval)

# 测试
if findMinAndMax([]) != (None, None):
    print('测试失败!')
elif findMinAndMax([7]) != (7, 7):
    print('测试失败!')
elif findMinAndMax([7, 1]) != (1, 7):
    print('测试失败!')
elif findMinAndMax([7, 1, 3, 9, 5]) != (1, 9):
    print('测试失败!')
else:
    print('测试成功!')

非迭代查找方法:

def findMinAndMax(list):
    if len(list)==0:
        return (None, None)
    list.sort()
    if(len(list))==1:
        return (list[0],list[0])
    else:
        return (list[0], list[-1])
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值