Здесь у меня есть метод setitem моего Двоичного дерева поиска. В настоящее время я получаю сообщение об ошибке «RecursionError: максимальная глубина рекурсии превышена», поэтому я хотел бы преобразовать его в итеративный метод, но я немного застрял. Есть намеки?
class BinarySearchTreeNode:
def __init__(self, key, item=None, left=None, right=None):
self.key = key
self.item = item
self.left = left
self.right = right
class BinarySearchTree:
def __init__(self):
self.root = None
def __setitem__(self, key, item):
self.root = self._setitem_aux_(self.root, key, item)
# here convert this to an iterative method
def _setitem_aux_(self, current, key, item):
if current is None:
current = BinarySearchTreeNode(key, item)
elif key < current.key:
current.left = self._setitem_aux_(current.left, key, item)
elif key > current.key:
current.right = self._setitem_aux_(current.right, key, item)
else: # key == current.key
current.item = item
return current
И назовите это:
bst = BinarySearchTree()
# To set an item with key = 0, item = 1
bst[0] = 1
# To set an item with key = "abcd", item = 10
bst["abcd"] = 10