如何加快Python链表上的递归调用?

时间:2014-05-21 15:03:46

标签: python performance recursion linked-list

我有一个名为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个元素我的功能效率不高。谢谢。

1 个答案:

答案 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