python2.7实现二叉树

from collections import deque
#结点中定义数据,左右节点
class Node:
    def __init__(self,data=-1,lchild=None,rchild=None):
        self.data=data
        self.lchild=lchild
        self.rchild=rchild

class CreateTree:
    def __init__(self):
        self.root=Node()
        self.myque=deque()

    # 加入结点(利用队列遍历建树)
    def add(self,elem):
        node=Node(elem)
        if self.root.data==-1:
            self.root=node
            self.myque.append(self.root)
        else:
            treenode=self.myque[0]
            if treenode.lchild==None:
                treenode.lchild=node
                self.myque.append(treenode.lchild)
            else:
                treenode.rchild=node
                self.myque.append(treenode.rchild)
                self.myque.popleft()
    #前序遍历(data->左结点->右结点)
    def digui_front(self,root):
        if root==None:
            return
        print root.data
        self.digui_front(root.lchild)
        self.digui_front(root.rchild)

    #中序遍历
    def digui_front(self,root):
        if root==None:
            return
        self.digui_front(root.lchild)
        print root.data
        self.digui_front(root.rchild)

    #后序遍历
    def digui_front(self,root):
        if root==None:
            return
        self.digui_front(root.lchild)
        self.digui_front(root.rchild)
        print root.data

    #计算树的深度
    def depth(self,root):
        if root==None:
            return 0
        ldepth,rdepth=self.depth(root.lchild),self.depth(root.rchild)
        return max(ldepth,rdepth)+1




if __name__=="__main__":
    elems=range(10)
    tree=CreateTree()
    for i in elems:
        tree.add(i)
    tree.digui_front(tree.root)
    m =tree.depth(tree.root)
    print m

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值