源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

python先序遍历二叉树问题

  • 时间:2021-09-22 22:42 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:python先序遍历二叉树问题
[b]问题[/b] [b]如何遍历一个二叉树[/b] 遍历二叉树就是访问二叉树的每一个节点 二叉树父结点下先左访问,先序遍历(根左右) 例如:遍历以下的二叉树 [img]http://files.jb51.net/file_images/article/201711/20171110104351802.png?2017101010449[/img] 遍历结果:ABDECF Python代码示例
# !/usr/bin/env python
# -*-encoding: utf-8-*-
# author:LiYanwei
# version:0.1


class TreeNode(object):
  '''
  二叉树类
  '''
  def __init__ (self, data, left = None, right = None):
    self.data = data
    self.left = left
    self.right = right

  def __str__(self):
    return str(self.data)

def createTree():
  '''
  创建二叉树函数
  '''
  # 创建如图的二叉树
  # 1.创建节点
  A = TreeNode('A')
  B = TreeNode('B')
  C = TreeNode('C')
  D = TreeNode('D')
  E = TreeNode('E')
  F = TreeNode('F')
  # 列表解析
  # A, B, C, D, E, F = [TreeNode(x) for x in 'ABCDEF']

  # 2.创建节点之间的关系
  A.left = B
  A.right = C
  B.left = D
  B.right = E
  C.left = F
  return A


def preOrder(node):
  '''
  先序遍历 先左后右 使用递归
  :param node:
  :return:
  '''
  if node is None:
    return
  print node.data
  preOrder(node.left)
  preOrder(node.right)

if __name__ == '__main__':
  # 二叉树的创建
  root = createTree()
  # 二叉树的遍历
  preOrder(root) 
[b]总结[/b] 以上就是本文关于python先序遍历二叉树问题的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:[url=http://www.1sucai.cn/article/127901.htm]Python3调用微信企业号API发送文本消息代码示例[/url]、[url=http://www.1sucai.cn/article/127878.htm]浅谈python中的占位符[/url]、[url=http://www.1sucai.cn/article/127804.htm]python实现人脸识别代码[/url]等,有什么问题可以随时留言,小编会及时回复大家的。感谢朋友们对本站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部