python实现二叉树的生成和递归遍历

本文介绍了如何使用Python实现二叉树的层次生成和递归遍历,包括前序遍历和中序遍历。通过类`Node`和`BT_Tree`的定义,展示了如何创建二叉树并进行不同方式的遍历,帮助读者理解递归和对象的概念。
摘要由CSDN通过智能技术生成

今日主题:温故而知新。关于树的生成和遍历是好早之前就学习了的知识,最近复习数据结构,重新学习了一遍,发现就是这个简单的知识点帮助我深入理解了递归和对象,(或者是我之前基础太菜了哈哈),好吧,我们来一起复习,一起进步吧~

二叉树的生成用的是层次法,实现时,是用一个list来保存节点值,然后按照层次法把这些点一个个加入树中,然后用前序和中序遍历法来遍历,都是递归实现。递归实现千万别想复杂了,举个前序遍历的栗子:把根节点输出,然后对左子节点调用前序遍历,然后对右子节点调用。好了代码中体会吧

class Node(object):
      def __init__(self,data=-1,lchild=None,rchild=None):
            self.data=data
            self.lchild=lchild
            self.rchild=rchild


            
class BT_Tree(object):
      def __init__(self):
            self.tree=None
      def build_tree(self,nodeList):
            if len(nodeList)==0:
                  return None
            root=Node(nodeList[0])
            nodes=[root]#把nodes定义为一个node类型的集合
            i=1
   

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值