zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    catboost原理以及Python代码
    lightgbm原理以及Python代码
    stacking算法原理及代码
    python自动化之爬虫模拟登录
    python自动化之爬虫原理及简单案例
    python自动化之PDF
    input type="file"鼠标无法变小手
    typescript中类和接口的区别
    TypeScript基础类型
    微信小程序-获取input值的两种方法
  • 原文地址:https://www.cnblogs.com/joangaga/p/7066551.html
Copyright © 2011-2022 走看看