TypeError:'int'对象不能使用max()迭代

人气:604 发布:2022-10-16 标签: recursion python arrays max typeerror

问题描述

我正在尝试使用Pythonmax()函数获取一些整数之间的最大值。然而,我得到了这个

TypeError: 'int' object is not iterable.

这是我的代码:

def main():
    inputs =[]
    inputted = int(raw_input())
    inputs.append(inputted)
    for i in range(0,inputs[0]):
        inputted = int(raw_input())
        inputs.append(inputted)
    total = valor_max(inputs[1::], 0, len(inputs)-1)

def valor_max(array, i, j):
    if (i == j):
        return array[0]
    elif (i == (j-1)):
        return (max(array[i], array[j]))
    else:
        return  max((array[i]+min(valor_max(array, i+2, j))) , valor_max(array, i+1, j-1), array[j]+min(valor_max(array, i+1, j-1)), valor_max(array,i,j-2))

main()

我在该行收到错误:return max((array[i]+min(valor_max(array, i+2, j))) , valor_max(array, i+1, j-1), array[j]+min(valor_max(array, i+1, j-1)), valor_max(array,i,j-2))

有人能解释一下为什么我不能通过这种方式达到最大值吗?谢谢!

推荐答案在该行中的某个点,valor_max属于第一种情况(i == j),并返回单个数字而不是可迭代对象。因此,min的两个调用之一将是min(singleNumber),这将导致您看到的错误消息。

您应该始终尝试返回相同的类型,而不是让valor_max函数根据大小写返回不同的类型。在你的案例中, 您想返回一个可迭代的、一个列表或一个元组。因此,您应该让第一个案例像其他两个案例一样返回一个:

return (array[0], ) # this creates a tuple with a single element

顺便说一下。对于如此长的行,将其分解为多个语句通常会有所帮助。这不仅允许您更好地查看属于哪一个参数(例如,您的代码在max的第一个参数周围有一些额外的圆括号,但不属于任何其他参数),而且它还允许Python告诉您错误发生的确切位置,而不是"在超长的行中的某个地方":

values = (
    array[i] + min(valor_max(array, i+2, j)),
    valor_max(array, i+1, j-1),
    array[j] + min(valor_max(array, i+1, j-1)),
    valor_max(array, i, j-2)
)
return max(values)

770