#coding:utf-8
#author:Elvis
class TreeNode(object):
def __init__(self):
self.data = '#'
self.l_child = None
self.r_child = None
class Tree(TreeNode):
#create a tree
def create_tree(self, tree):
data = raw_input('->')
if data == '#':
tree = None
else:
tree.data = data
tree.l_child = TreeNode()
self.create_tree(tree.l_child)
tree.r_child = TreeNode()
self.create_tree(tree.r_child)
#visit a tree node
def visit(self, tree):
#输入#号代表空树
if tree.data is not '#':
print str(tree.data) + '\t',
#先序遍历
def pre_order(self, tree):
if tree is not None:
self.visit(tree)
self.pre_order(tree.l_child)
self.pre_order(tree.r_child)
#中序遍历
def in_order(self, tree):
if tree is not None:
self.in_order(tree.l_child)
self.visit(tree)
self.in_order(tree.r_child)
#后序遍历
def post_order(self, tree):
if tree is not None:
self.post_order(tree.l_child)
self.post_order(tree.r_child)
self.visit(tree)
t = TreeNode()
tree = Tree()
tree.create_tree(t)
tree.pre_order(t)
print '\n'
tree.in_order(t)
print '\n'
tree.post_order(t)
python实现二叉树的创建和遍历
原创
©著作权归作者所有:来自51CTO博客作者wx6464351503832的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
创建二叉树并遍历二叉树
刚刚接触二叉树的同学一很想学习如何构建一颗简单的二叉树,下面我用C语言来实现一个简单的二叉树,并且用先
二叉树 遍历 先序遍历 中序遍历 后序遍 子树 二叉树 #include -
二叉树:二叉搜索树的创建和插入
二叉搜索树又名二叉排序树。大概简略的思维导图如下,方便记忆特性基本二叉
#include 二叉搜索树 ios -
Python实现二叉树的遍历
Python实现二叉树的遍历
python 二叉树 前序遍历 -
二叉树广度遍历 java 二叉树遍历实现
前言 二叉树的三种遍历实现,即前序遍历、中序遍历、后序遍历
二叉树广度遍历 java 非递归 后序遍历 递归