• python 实现二叉树 求二叉树的叶子节点个数


    #coding=utf-8

    class Node(object):
    """节点类"""
    def __init__(self, elem=-1, lchild=None, rchild=None):
    self.elem = elem
    self.lchild = lchild
    self.rchild = rchild
    class Tree(object):
    """树类"""
    def __init__(self):
    self.root = Node()
    self.myQueue = []

    def add(self, elem):
    """为树添加节点"""
    node = Node(elem)
    if self.root.elem == -1: # 如果树是空的,则对根节点赋值
    self.root = node
    self.myQueue.append(self.root)
    else:
    treeNode = self.myQueue[0] # 此结点的子树还没有齐。
    if treeNode.lchild == None:
    treeNode.lchild = node
    self.myQueue.append(treeNode.lchild)
    else:
    treeNode.rchild = node
    self.myQueue.append(treeNode.rchild)
    self.myQueue.pop(0) # 如果该结点存在右子树,将此结点丢弃。
      
      
      def leave(self,root):   #递归求叶子节点个数
      if root==None:
      return 0
      elif root.lchild ==None and root.rchild == None :
      return 1
      else:
      return (self.leave(root.lchild)+self.leave(root.rchild))

    if __name__ == '__main__':
    """主函数"""
    elems = range(10) #生成十个数据作为树节点
    tree = Tree() #新建一个树对象
    for elem in elems:
    tree.add(elem) #逐个添加树的节点
      print '
    叶子节点个数:'
      num = tree.leave(tree.root)
      print num
  • 相关阅读:
    Mybatis中#{}和${}传参的区别
    笔记摘抄 —— shiro学习篇
    使用Spring的Testcase的单元测试的写法
    【转】FreeMarker学习笔记
    破解Pycharm,IDEA,PhpStrom等系列产品的,有关JetbrainsCrack的使用方法
    Python的字符串
    python的变量
    python开头注释
    h5-动画小案例-滚动展示
    h5-钟表动画案例
  • 原文地址:https://www.cnblogs.com/joangaga/p/7066551.html
Copyright © 2020-2023  润新知