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

作者:玩蛇的 时间:2022-08-22 03:59:30 

问题

创建一个二叉树

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

空集

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

创建二叉树:

创建节点

再创建节点之间的关系

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)

来源:http://www.cnblogs.com/Py00/p/7726550.html

标签:python,二叉树
0
投稿

猜你喜欢

  • CSS图片代码效果汇总

    2008-09-04 12:14:00
  • Golang使用Gin框架实现路由分类处理请求流程详解

    2024-05-29 22:07:41
  • Python 随机生成中文验证码的实例代码

    2022-12-15 23:17:34
  • Matlab实现图像边缘检测

    2021-02-06 07:40:58
  • 用纯CSS3绘制的网站图标

    2010-03-28 13:51:00
  • Python 实现list,tuple,str和dict之间的相互转换

    2021-02-28 12:35:42
  • asp使用session防止网页频繁刷新

    2007-09-26 14:25:00
  • 提升网站可用性的3个忠告

    2008-01-31 13:48:00
  • python3.4中清屏的处理方法

    2023-11-14 04:09:21
  • Python中的sys.stdout.write实现打印刷新功能

    2022-01-17 14:51:50
  • 详细解读python操作json文件的详细

    2021-01-31 10:41:42
  • 如何使用python爬取知乎热榜Top50数据

    2021-11-13 05:47:09
  • Go语言实现RSA加解密算法详解

    2024-02-08 12:20:55
  • Python如何省略括号方法详解

    2022-12-11 07:23:26
  • 基于Python写一个番茄钟小工具

    2023-05-02 07:53:37
  • 树莓派4B+opencv4+python 打开摄像头的实现方法

    2021-05-04 12:09:37
  • 简单方法实现Vue 无限滚动组件示例

    2023-07-02 16:50:14
  • python 引用传递和值传递详解(实参,形参)

    2023-10-25 15:57:44
  • js实现网页标题栏闪烁提示效果实例分析

    2024-04-16 09:05:11
  • Python requests模块安装及使用教程图解

    2022-08-10 15:29:45
  • asp之家 网络编程 m.aspxhome.com