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实现根据指定端口探测服务器/模块部署的方法
Aug 25 Python
Python文件和目录操作详解
Feb 08 Python
全面理解Python中self的用法
Jun 04 Python
Python下的Softmax回归函数的实现方法(推荐)
Jan 26 Python
Python简单生成随机数的方法示例
Mar 31 Python
python获取酷狗音乐top500的下载地址 MP3格式
Apr 17 Python
Python3使用SMTP发送带附件邮件
Jun 16 Python
python中字符串内置函数的用法总结
Sep 13 Python
Python虚拟环境的原理及使用详解
Jul 02 Python
python 爬虫百度地图的信息界面的实现方法
Oct 27 Python
python_array[0][0]与array[0,0]的区别详解
Feb 18 Python
Django分组聚合查询实例分享
Apr 29 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
Flash空降上海 化身大魔王接受挑战
2020/03/02 星际争霸
详细介绍:Apache+PHP+MySQL配置攻略
2006/09/05 PHP
PHP中if和or运行效率对比
2014/12/12 PHP
WebQQ最新登陆协议的用法
2014/12/22 PHP
thinkPHP使用post方式查询时分页失效的解决方法
2015/12/09 PHP
yii2项目实战之restful api授权验证详解
2017/05/20 PHP
jquery中常用的SET和GET
2009/01/13 Javascript
JavaScript和JQuery实用代码片段(一)
2010/04/07 Javascript
js读写cookie实现一个底部广告浮层效果的两种方法
2013/12/29 Javascript
Javascript递归打印Document层次关系实例分析
2015/05/15 Javascript
浅谈javascript的Array.prototype.slice.call
2015/08/31 Javascript
基于jquery实现简单的手风琴特效
2015/11/24 Javascript
浅谈javascript中的加减时间
2016/07/12 Javascript
jQuery展示表格点击变色、全选、删除
2017/01/05 Javascript
微信小程序商品详情页的底部弹出框效果
2020/11/16 Javascript
详解在Node.js中发起HTTP请求的5种方法
2019/01/10 Javascript
Javascript ParentNode和ChildNode接口原理解析
2020/03/16 Javascript
vue点击标签切换选中及互相排斥操作
2020/07/17 Javascript
vue实现抽屉弹窗效果
2020/11/15 Javascript
[03:57]2016完美“圣”典风云人物:rOtk专访
2016/12/09 DOTA
[01:00:35]2018DOTA2亚洲邀请赛3月30日B组 EffcetVSMineski
2018/03/31 DOTA
php使用递归与迭代实现快速排序示例
2014/01/23 Python
Python中逗号的三种作用实例分析
2015/06/08 Python
python实现zabbix发送短信脚本
2018/09/17 Python
python实现图片筛选程序
2018/10/24 Python
Pandas过滤dataframe中包含特定字符串的数据方法
2018/11/07 Python
三星新西兰官网:Samsung新西兰
2019/03/05 全球购物
State Cashmere官网:半零售价可持续蒙古羊绒
2020/02/26 全球购物
前台文员岗位职责及工作流程
2013/11/19 职场文书
大学军训感言300字
2014/03/09 职场文书
2014教师专业技术工作总结
2014/12/03 职场文书
2015共产党员公开承诺书
2015/01/22 职场文书
小学秋季运动会通讯稿
2015/11/25 职场文书
家庭教育培训学习心得体会
2016/01/14 职场文书
浅谈PostgreSQL表分区的三种方式
2021/06/29 PostgreSQL
python之django路由和视图案例教程
2021/07/26 Python