У меня есть дерево сегментов, которое содержит данные для диапазона чисел (выбранная структура данных здесь ). Вот код:
class SegmentTree:
def __init__(self, N):
def _init(b, e):
if b is e:
data = foo() # No dependency
return Node(b, e, data, None, None)
else:
mid = (b + e ) / 2
L = _init(b, mid)
R = _init(mid + 1, e)
data = foo() #Data depends on L and R
return Node(b, e, data, L, R)
self.root = _init(1, N)
Сбой для N около 300 с ошибкой превышения максимальной глубины рекурсии. Есть ли способ создать дерево итеративно, а не рекурсивно?