当前位置:   article > 正文

算法与数据结构Python——Lesson6

算法与数据结构Python——Lesson6

二叉树的基本概念

二叉树是每个节点最多有两个子树的树结构。通常子树被称作“左子树”(left subtree)和“右子树”(right subtree)

二叉树的遍历

树的遍历是树的一种重要的运算。所谓遍历是指对树中所有结点的信息的访问,即依次对树中每个结点访问一次且仅访问一次,我们把这种对所有节点的访问称为遍历(traversal)。那么树的两种重要的遍历模式是深度优先遍历和广度优先遍历,深度优先一般用递归,广度优先一般用队列。一般情况下能用递归实现的算法大部分也能用堆栈来实现。

深度优先遍历

对于一颗二叉树,深度优先搜索(Depth First Search)是沿着树的深度遍历树的节点,尽可能深的搜索树的分支。
那么深度遍历有重要的三种方法。这三种方式常被用于访问树的节点,它们之间的不同在于访问每个节点的次序不同。这三种遍历分别叫做先序遍历(preorder),中序遍历(inorder)和后序遍历(postorder)。我们来给出它们的详细定义,然后举例看看它们的应用。

  • 先序遍历 在先序遍历中,我们先访问根节点,然后递归使用先序遍历访问左子树,再递归使用先序遍历访问右子树
    根节点->左子树->右子树
  • 中序遍历 在中序遍历中,我们递归使用中序遍历访问左子树,然后访问根节点,最后再递归使用中序遍历访问右子树
    左子树->根节点->右子树
  • 后序遍历 在后序遍历中,我们先递归使用后序遍历访问左子树和右子树,最后访问根节点
    左子树->右子树->根节点
  1. class Node(object):
  2. """"""
  3. def __init__(self, item):
  4. self.elem = item
  5. self.lchild = None
  6. self.rchild = None
  7. class Tree(object):
  8. """二叉树"""
  9. def __init__(self):
  10. self.root = None
  11. def add(self, item):
  12. node = Node(item)
  13. if self.root is None:
  14. self.root = node
  15. return
  16. queue = [self.root]
  17. while queue:
  18. cur_node = queue.pop(0)
  19. if cur_node.lchild is None:
  20. cur_node.lchild = node
  21. return
  22. else:
  23. queue.append(cur_node.lchild)
  24. if cur_node.rchild is None:
  25. cur_node.rchild = node
  26. return
  27. else:
  28. queue.append(cur_node.rchild)
  29. def breadth_travel(self):
  30. """广度遍历"""
  31. if self.root is None:
  32. return
  33. queue = [self.root]
  34. while queue:
  35. cur_node = queue.pop(0)
  36. print(cur_node.elem, end=" ")
  37. if cur_node.lchild is not None:
  38. queue.append(cur_node.lchild)
  39. if cur_node.rchild is not None:
  40. queue.append(cur_node.rchild)
  41. def preorder(self, node):
  42. """先序遍历"""
  43. if node is None:
  44. return
  45. print(node.elem, end=" ")
  46. self.preorder(node.lchild)
  47. self.preorder(node.rchild)
  48. def inorder(self, node):
  49. """中序遍历"""
  50. if node is None:
  51. return
  52. self.inorder(node.lchild)
  53. print(node.elem, end=" ")
  54. self.inorder(node.rchild)
  55. def postorder(self, node):
  56. """后序遍历"""
  57. if node is None:
  58. return
  59. self.postorder(node.lchild)
  60. self.postorder(node.rchild)
  61. print(node.elem, end=" ")
  62. if __name__ == "__main__":
  63. tree = Tree()
  64. tree.add(0)
  65. tree.add(1)
  66. tree.add(2)
  67. tree.add(3)
  68. tree.add(4)
  69. tree.add(5)
  70. tree.add(6)
  71. tree.add(7)
  72. tree.add(8)
  73. tree.add(9)
  74. tree.breadth_travel()
  75. print(" ")
  76. tree.preorder(tree.root)
  77. print(" ")
  78. tree.inorder(tree.root)
  79. print(" ")
  80. tree.postorder(tree.root)
  81. print(" ")

输出结果:

0 1 2 3 4 5 6 7 8 9  
0 1 3 7 8 4 9 2 5 6  
7 3 8 1 9 4 0 5 2 6  
7 8 3 9 4 1 5 6 2 0  

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/561312
推荐阅读
相关标签
  

闽ICP备14008679号