根据二叉树的抽象数据类型的定义,使用二叉链表实现一个二叉树。 二叉树的基本功能: 1、二叉树的建立 2、前序遍历二叉树 3、中序遍历二叉树 4、后序遍历二叉树 5、按层序遍历二叉树 6、求二叉树的深度 7、求指定结点到根的路径 8、二叉树的销毁 9、其他:自定义操作 编写测试 main()函数测试二叉树的正确性
时间: 2023-11-16 17:05:38 浏览: 96
好的,我了解了你的要求。下面是二叉树的链表实现及其基本功能的代码实现:
```python
class TreeNode:
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right
class BinaryTree:
def __init__(self, root=None):
self.root = root
# 建立二叉树
def buildTree(self, nodes):
if not nodes:
return None
val = nodes.pop(0)
if val is None:
return None
root = TreeNode(val)
root.left = self.buildTree(nodes)
root.right = self.buildTree(nodes)
return root
# 前序遍历二叉树
def preorderTraversal(self, root):
if not root:
return
print(root.val, end=' ')
self.preorderTraversal(root.left)
self.preorderTraversal(root.right)
# 中序遍历二叉树
def inorderTraversal(self, root):
if not root:
return
self.inorderTraversal(root.left)
print(root.val, end=' ')
self.inorderTraversal(root.right)
# 后序遍历二叉树
def postorderTraversal(self, root):
if not root:
return
self.postorderTraversal(root.left)
self.postorderTraversal(root.right)
print(root.val, end=' ')
# 按层序遍历二叉树
def levelorderTraversal(self, root):
if not root:
return
queue = [root]
while queue:
node = queue.pop(0)
print(node.val, end=' ')
if node.left:
queue.append(node.left)
if node.right:
queue.append(node.right)
# 求二叉树的深度
def depth(self, root):
if not root:
return 0
left_depth = self.depth(root.left)
right_depth = self.depth(root.right)
return max(left_depth, right_depth) + 1
# 求指定结点到根的路径
def path(self, root, val, path_list):
if not root:
return False
path_list.append(root.val)
if root.val == val:
return True
if (root.left and self.path(root.left, val, path_list)) or (root.right and self.path(root.right, val, path_list)):
return True
path_list.pop()
return False
# 二叉树的销毁
def destroy(self, root):
if not root:
return
self.destroy(root.left)
self.destroy(root.right)
del root
# 自定义操作
def customOperation(self, root):
# 自定义操作的实现
pass
if __name__ == '__main__':
nodes = [1, 2, 4, None, None, 5, None, None, 3, None, 6, None, None]
binaryTree = BinaryTree()
binaryTree.root = binaryTree.buildTree(nodes)
print('前序遍历:', end='')
binaryTree.preorderTraversal(binaryTree.root)
print()
print('中序遍历:', end='')
binaryTree.inorderTraversal(binaryTree.root)
print()
print('后序遍历:', end='')
binaryTree.postorderTraversal(binaryTree.root)
print()
print('按层序遍历:', end='')
binaryTree.levelorderTraversal(binaryTree.root)
print()
print('二叉树深度:', binaryTree.depth(binaryTree.root))
path_list = []
binaryTree.path(binaryTree.root, 5, path_list)
print('指定结点到根的路径:', path_list)
binaryTree.destroy(binaryTree.root)
```
在这个代码实现中,我们使用 TreeNode 类来创建二叉树的结点,使用 BinaryTree 类来实现二叉树的链表实现并实现了二叉树的各种基本功能。在测试的 main() 函数中,我们首先使用一个列表来表示二叉树的结点,然后调用 BinaryTree 类中的 buildTree() 方法来构造二叉树,接着分别调用其他方法来测试二叉树的各种功能。最后,我们调用 destroy() 方法来销毁二叉树。
阅读全文