我有一个名为min_max
的递归函数;它被传递一个链表;它返回一个包含最小值后跟最大值的2元组。如果链接列表为空,则min_max
将返回(None, None)
。例如,如果我们将此函数称为min_max(list_to_ll([1, 3, 7, 2, 0]))
,则返回的结果将为(0, 7)
。
class LN:
def __init__(self,value,next=None):
self.value = value
self.next = next
def list_to_ll(l):
if l == []:
return None
front = rear = LN(l[0])
for v in l[1:]:
rear.next = LN(v)
rear = rear.next
return front
def min_max(ll):
if ll == None:
return (None,None)
else:
result = (ll.value,ll.value)
if ll.next != None:
return (min(result[0],min_max(ll.next)[0]),max(result[1],min_max(ll.next)[1]))
else:
return result
if __name__ == '__main__':
print('\nTesting min_max')
print(min_max(None))
print(min_max(list_to_ll([0])))
print(min_max(list_to_ll([7, 3, 5, 2, 0])))
print(min_max(list_to_ll([1, 3, 5, 2, 7])))
values = [i for i in range(1,100)]
print(values)
print(min_max(list_to_ll(values)))
我的问题是如何加速链接列表中的递归调用min_max,可能包含100个元素?我可以传递test_case以链接5-7个元素但是有100个元素我的功能效率不高。谢谢。
答案 0 :(得分:4)
目前,这一行:
return (min(result[0],min_max(ll.next)[0]),max(result[1],min_max(ll.next)[1]))
以递归两次调用min_max
来获取最小值和最大值 - 这意味着您对2**n
而不是min_max
进行n
次调用,是一个巨大的惩罚。相反,请考虑:
min_, max_ = min_max(ll.next) # call once
return min(min_, ll.value), max(max_, ll.value) # use the two values