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


Posted in Python onOctober 27, 2017

问题

创建一个二叉树

二叉树有限多个节点的集合,这个集合可能是:

空集

由一个根节点,和两棵互不相交的,分别称作左子树和右子树的二叉树组成

创建二叉树:

创建节点

再创建节点之间的关系

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

问题

求n个节点不同二叉树个数

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个节点

递归进行累加

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)

总结

以上就是本文关于Python算法之求n个节点不同二叉树个数的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:Python探索之自定义实现线程池、python中模块的__all__属性详解等,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

Python 相关文章推荐
Python实现扫描指定目录下的子目录及文件的方法
Jul 16 Python
python实现kNN算法识别手写体数字的示例代码
Aug 16 Python
Python 实现的 Google 批量翻译功能
Aug 26 Python
在python中利用try..except来代替if..else的用法
Dec 19 Python
使用python3批量下载rbsp数据的示例代码
Dec 20 Python
python每5分钟从kafka中提取数据的例子
Dec 23 Python
Python中import导入不同目录的模块方法详解
Feb 18 Python
python实现根据给定坐标点生成多边形mask的例子
Feb 18 Python
python 串行执行和并行执行实例
Apr 30 Python
如何理解python中数字列表
May 29 Python
PyQt5.6+pycharm配置以及pyinstaller生成exe(小白教程)
Jun 02 Python
Python中time与datetime模块使用方法详解
Mar 31 Python
Python探索之自定义实现线程池
Oct 27 #Python
python音频处理用到的操作的示例代码
Oct 27 #Python
彻底理解Python list切片原理
Oct 27 #Python
Python在不同目录下导入模块的实现方法
Oct 27 #Python
Django视图之ORM数据库查询操作API的实例
Oct 27 #Python
浅谈python函数之作用域(python3.5)
Oct 27 #Python
python+pyqt实现右下角弹出框
Oct 26 #Python
You might like
YII中assets的使用示例
2014/07/31 PHP
php实现TCP端口检测的方法
2015/04/01 PHP
php判断linux下程序问题实例
2015/07/09 PHP
[原创]php简单防盗链验证实现方法
2016/07/09 PHP
关于Anemometer图形化显示MySQL慢日志的工具搭建及使用的详细介绍
2020/07/13 PHP
自适应图片大小的弹出窗口
2006/07/27 Javascript
setTimeout与setInterval在不同浏览器下的差异
2010/01/24 Javascript
Jquery图片滚动与幻灯片的实例代码
2013/04/08 Javascript
JQuery中form验证出错信息的查看方法
2013/10/08 Javascript
js实现幻灯片播放图片示例代码
2013/11/07 Javascript
jquery插件推荐浏览器嗅探userAgent
2014/11/09 Javascript
jQuery拖拽插件gridster使用指南
2015/04/21 Javascript
jQuery编写网页版2048小游戏
2017/01/06 Javascript
Angular多选、全选、批量选择操作实例代码
2017/03/10 Javascript
微信小程序swiper实现文字纵向轮播提示效果
2020/01/21 Javascript
typescript配置alias的详细步骤
2020/08/12 Javascript
[09:47]2018DOTA2亚洲邀请赛4.5SOLO赛 No[o]ne vs Sumail
2018/04/06 DOTA
[02:42]DOTA2城市挑战赛收官在即 四强之争风起云涌
2018/06/05 DOTA
[58:46]OG vs NAVI 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
[01:55]TI9显影之尘系列 - Evil Geniuses
2019/08/22 DOTA
python实现统计代码行数的方法
2015/05/22 Python
Python采用Django制作简易的知乎日报API
2016/08/03 Python
python使用TensorFlow进行图像处理的方法
2018/02/28 Python
使用python根据端口号关闭进程的方法
2018/11/06 Python
在python image 中安装中文字体的实现方法
2019/08/22 Python
如何关掉pycharm中的python console(图解)
2019/10/31 Python
python开根号实例讲解
2020/08/30 Python
Shopee印度尼西亚:东南亚与台湾市场最大电商平台
2018/06/17 全球购物
MUGLER官方网站:蒂埃里·穆勒香水
2019/11/26 全球购物
怎样比较两个类型为String的字符串
2016/08/17 面试题
职工运动会邀请函
2014/02/02 职场文书
文明城市创建标语
2014/06/16 职场文书
结婚保证书
2015/01/16 职场文书
小学音乐教师个人工作总结
2015/02/05 职场文书
如何在Python项目中引入日志
2021/05/31 Python
Python中Selenium对Cookie的操作方法
2021/07/09 Python