python在二叉树中搜索节点
我在二叉树中搜索有困难, 我想检查根目录是否存在,但遇到错误。 我做错了什么 这是我的完整代码:python在二叉树中搜索节点,python,python-3.x,class,binary-tree,Python,Python 3.x,Class,Binary Tree,我在二叉树中搜索有困难, 我想检查根目录是否存在,但遇到错误。 我做错了什么 这是我的完整代码: class Node: def __init__(self, data): self.left = None self.right = None self.data = data def printTree(self): if self.left: self.left.PrintTree()
class Node:
def __init__(self, data):
self.left = None
self.right = None
self.data = data
def printTree(self):
if self.left:
self.left.PrintTree()
print(self.data),
if self.right:
self.right.PrintTree()
def insert(self, data):
""" Compare the new value with the parent node """
if self.data:
if data < self.data:
if self.left is None:
self.left = Node(data)
else:
self.left.insert(data)
elif data > self.data:
if self.right is None:
self.right = Node(data)
else:
self.right.insert(data)
else:
self.data = data
def is_exist(self, val):
if val < self.data:
if self.left is None:
return None, None
return self.left.exists(val, self)
elif val > self.data:
if self.right is None:
return None, None
return self.right.exists(val, self)
else:
return self.data
我得到的厄洛尔:
return self.left.exists(val, self)
AttributeError: 'Node' object has no attribute 'exists'
您用错误的名称调用函数。此外,如果调用对象的方法,则不会指定
self
。看见您编写了return self.right.exists(val,self)
,但您应该编写return self.right.is_exist(val)
self.left.exists
不在您的代码中。你的意思是self.left.is_exist()
?很抱歉,我的所有测试都改变了它。。。但是还是不行。对不起,我错过了你的第二道题。我编辑了我的答案。
return self.left.exists(val, self)
AttributeError: 'Node' object has no attribute 'exists'