源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Python算法之求n个节点不同二叉树个数

  • 时间:2021-08-13 19:23 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Python算法之求n个节点不同二叉树个数
[b]问题[/b] [b]创建一个二叉树[/b] 二叉树有限多个节点的集合,这个集合可能是: 空集 由一个根节点,和两棵互不相交的,分别称作左子树和右子树的二叉树组成 [b]创建二叉树:[/b] 创建节点 再创建节点之间的关系 Python代码示例
# !/usr/bin/env python
# -*-encoding: utf-8-*-
# author:LiYanwei
# version:0.1
class TreeNode(object):
  def __init__ (self, data, left = None, right = None):
    self.data = data
    self.left = left
    self.right = right
  def __str__(self):
    return str(self.data)
# 节点
A = TreeNode('A')
B = TreeNode('B')
C = TreeNode('C')
D = TreeNode('D')
# 节点间的关系
A.left = B
A.right = C
B.right = D
print B.right
[b]问题[/b] [b]求n个节点不同二叉树个数 [/b] 1个节点 根节点1 1种 1种二叉树 2个节点 根节点1 左节点1 1种(依照1节点的推断) 根节点1 右节点1 1种(依照1节点的推断) 2种二叉树 3个节点 根节点1 左节点0 右节点2 2种(依照2节点的推断) 根节点1 左节点1 右节点1 1种(依照1节点的推断) 根节点1 左节点2 右节点0 2种(依照2节点的推断) 5种二叉树 4个节点 根节点1 左节点0 右节点3 5种(依照3节点的推断) 根节点1 左节点1 右节点2 2种(依照2节点的推断) 根节点1 左节点2 右节点1 2种(依照2节点的推断) 根节点1 左节点3 右节点0 5种(依照4上面的推断) 共14种二叉树 ... n个节点 [b]递归进行累加[/b] Python代码示例
# !/usr/bin/env python
# -*-encoding: utf-8-*-
# author:LiYanwei
# version:0.1
# 求n个节点不同二叉树个数
def count(n):
  # root : 1
  # left : k
  # right : n - 1- k
  # s = 0
  # if n == 0:
  #   # 空树
  #   return 1
  s = count.cache.get(n, 0)
  if s:
    return s
  for k in xrange(n):
    s += count(k) * count(n - 1 - k)
  count.cache[n] = s
  return s
# 重复计算优化
count.cache = {0 : 1}
print count(100)
[b]总结[/b] 以上就是本文关于Python算法之求n个节点不同二叉树个数的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:[url=http://www.1sucai.cn/article/126987.htm]Python探索之自定义实现线程池[/url]、[url=http://www.1sucai.cn/article/126875.htm]python中模块的__all__属性详解[/url]等,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部