Python算法之求n个节点不同二叉树个数
问题
创建一个二叉树
二叉树有限多个节点的集合,这个集合可能是:
空集
由一个根节点,和两棵互不相交的,分别称作左子树和右子树的二叉树组成
创建二叉树:
创建节点
再创建节点之间的关系
Python代码示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | # !/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代码示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | # !/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__属性详解等,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

微信公众号搜索 “ 脚本之家 ” ,选择关注
程序猿的那些事、送书等活动等着你
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!
相关文章
Python pkg_resources模块动态加载插件实例分析
当编写应用软件时,我们通常希望程序具有一定的扩展性,额外的功能——甚至所有非核心的功能,都能通过插件实现,具有可插拔性。特别是使用 Python 编写的程序,由于语言本身的动态特性,为我们的插件方案提供了很多种实现方式2022-08-08Python上级目录文件导入的几种方法(from.import)
有时候我们可能需要import另一个路径下的python文件,下面这篇文章主要给大家介绍了关于Python上级目录文件导入的几种方法,文中通过代码介绍的非常详细,需要的朋友可以参考下2023-12-12
最新评论