[英]Recursive Binary Search Tree Python
我想在python中实现一个带有元素、左右孩子和父母的二叉搜索树。
class BSTNode:
""" An internal node for a BST . """
def __init__(self, item):
""" Initialise a BSTNode on creation, with value==item. """
self._element = item
self._leftchild = None
self._rightchild = None
self._parent = None
def __str__(self):
node = self
if node != None:
s = str(node._element)
if node._leftchild:
node._leftchild.__str__()
s = str(node._element)
s+= ' '
elif node._rightchild:
node._rightchild.__str__()
s += str(node._element)
else:
return s
else:
return ''
def add(self, item):
node = self
if node:
if item <node._element :
if node._leftchild is None:
node._leftchild = BSTNode(item)
node._leftchild._parent = node
else:
node._leftchild.add(item)
elif item > node._element:
if node._rightchild is None:
node._rightchild = BSTNode(item)
node._rightchild._parent = node
else:
node._rightchild.add(item)
tree = BSTNode(3);
tree.add(7);
print(tree.__str__());
我写了这个程序,但是当我运行它时,它输出None,但它应该输出3 7(顺序是中序遍历)。 有谁知道我做错了什么?
您的__str__
方法不正确。 具体来说,您调用左右孩子的__str__()
但不对结果做任何事情。 另请注意,一个节点可以同时具有左子节点和右子节点( if...elif
只会检查一个)。 如果您遇到if
或elif
块之一,您也不会返回s
。
您可以将其简化为:
def __str__(self):
node = self
if node != None:
s = str(node._element)
if node._leftchild:
s = node._leftchild.__str__() + s
if node._rightchild:
s += ' ' + node._rightchild.__str__()
return s
return ''
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.