python3实现在二叉树中找出和为某一值的所有路径(推荐)


Posted in Python onDecember 26, 2019

请写一个程序创建一棵二叉树,并按照一定规则,输出二叉树根节点到叶子节点的路径。

规则如下:

1、从最顶端的根结点,到最下面的叶子节点,计算路径通过的所有节点的和,如果与设置的某一值的相同,那么输出这条路径上的所有节点。

2、从根节点遍历树时,请请按照左到右遍历,即优先访问左子树的节点。

二叉树创建规则:从上到下一层一层的,按照从左到右的顺序进行构造

输入"10,5,12,4,7"值,构造的树如下:

1) 10
2) 10
      /
    5

3) 10
       /\
     5 12
4) 10
        /\
      5 12
     /
   4

5) 10
        /\
      5 12
      /\
     4 7

针对上面的二叉树,如果当前我们设置的“路径和”为19,那么输出结果为:
10,5,4

如果有多个路径,按到左到右的顺序遍历生成的结果每行显示一个显示。例如如果当前我们设置的“路径和”为22,那么

输出结果为:

10,5,7
10,12

如果没有找到路径和为设置的值的路径,输出error。

三、输入:

输入整数N---路径和
一行字符串,多个正整数,之间用","隔开

四、输出: 满足条件的二叉树路径

五、样例输入:

22
10,5,12,4,7

六、样例输出:

10,5,7
10,12

demo:

class Node(object):
  def __init__(self, x):
   self.val = x
   self.left = None
   self.right = None
class Tree(object):
 lt = [] # 依次存放左右孩子未满的节点
 def __init__(self):
   self.root = None
 def add(self, number):
   node = Node(number) # 将输入的数字节点化,使其具有左右孩子的属性
   if self.root == None:
     self.root = node
     Tree.lt.append(self.root)
   else:
     while True:
       point = Tree.lt[0] # 依次对左右孩子未满的节点分配孩子
       if point.left ==None:
         point.left = node
         Tree.lt.append(point.left) # 该节点后面作为父节点也是未满的,也要加入到列表中。
         return
       elif point.right ==None:
         point.right = node
         Tree.lt.append(point.right) # 与左孩子同理
         Tree.lt.pop(0) # 表示该节点已拥有左右孩子,从未满列表中去除
         return
class Solution:
 def __init__(self):
   self.results = []
 def RecursionFindPath(self, root, expectNumber, result):
   result.append(root.val)
   if root.left == None and root.right == None and sum(result) == expectNumber:
     self.results.append(result)
   temp = result[:]
   if root.left:
     self.RecursionFindPath(root.left, expectNumber, result)
   result = temp[:]
   if root.right:
     self.RecursionFindPath(root.right, expectNumber, result)
 def FindPath(self, root, expectNumber):
   if root == None:
     return []
   self.RecursionFindPath(root, expectNumber, [])
   self.results = sorted(self.results, key=len, reverse=True)
   return self.results
if __name__ =='__main__':
 t = Tree() # 二叉树类的实例化
 L = [10, 5, 12, 4, 7]
 for i in L:
   t.add(i)
 expectNum = 22
 print(Solution().FindPath(t.root, expectNum))

输出样例:

python3实现在二叉树中找出和为某一值的所有路径(推荐)

总结

以上所述是小编给大家介绍的python3实现在二叉树中找出和为某一值的所有路径,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
详解Python3中的Sequence type的使用
Aug 01 Python
python+matplotlib绘制3D条形图实例代码
Jan 17 Python
pycharm+django创建一个搜索网页实例代码
Jan 24 Python
python实现从pdf文件中提取文本,并自动翻译的方法
Nov 28 Python
Python多进程方式抓取基金网站内容的方法分析
Jun 03 Python
使用TensorFlow-Slim进行图像分类的实现
Dec 31 Python
pytorch实现mnist分类的示例讲解
Jan 10 Python
基于pytorch的lstm参数使用详解
Jan 14 Python
Python3 获取文件属性的方式(时间、大小等)
Mar 12 Python
python语言中有算法吗
Jun 16 Python
python opencv pytesseract 验证码识别的实现
Aug 28 Python
Python与C/C++的相互调用案例
Mar 04 Python
Pytorch中Tensor与各种图像格式的相互转化详解
Dec 26 #Python
基于h5py的使用及数据封装代码
Dec 26 #Python
python深copy和浅copy区别对比解析
Dec 26 #Python
详解python opencv、scikit-image和PIL图像处理库比较
Dec 26 #Python
torch 中各种图像格式转换的实现方法
Dec 26 #Python
python两个_多个字典合并相加的实例代码
Dec 26 #Python
Python时间差中seconds和total_seconds的区别详解
Dec 26 #Python
You might like
国王的咖啡这么大来头,名字的由来是什么
2021/03/03 咖啡文化
PHP脚本的10个技巧(4)
2006/10/09 PHP
Discuz7.2版的faq.php SQL注入漏洞分析
2014/08/06 PHP
php常用正则函数实例小结
2016/12/29 PHP
php表单习惯用的正则表达式
2017/10/11 PHP
php设计模式之单例模式用法经典示例分析
2019/09/20 PHP
javascript 面向对象编程基础 多态
2009/08/21 Javascript
网页禁用右键实现代码(JavaScript代码)
2009/10/29 Javascript
JavaScript QueryString解析类代码
2010/01/17 Javascript
详解jquery uploadify 上传文件
2013/11/09 Javascript
jQuery操作表格(table)的常用方法、技巧汇总
2014/04/12 Javascript
基于promise.js实现nodejs的promises库
2014/07/06 NodeJs
推荐 21 款优秀的高性能 Node.js 开发框架
2014/08/18 Javascript
jQuery表格列宽可拖拽改变且兼容firfox
2014/09/03 Javascript
$("").click与onclick的区别示例介绍
2014/09/25 Javascript
jQuery检测返回值的数据类型
2015/07/13 Javascript
AngularJs学习第五篇从Controller控制器谈谈$scope作用域
2016/06/08 Javascript
使用Vue CLI创建typescript项目的方法
2019/08/09 Javascript
vue.js实现三级菜单效果
2019/10/19 Javascript
javascript实现拼图游戏
2021/01/29 Javascript
使用Python脚本来控制Windows Azure的简单教程
2015/04/16 Python
python Flask实现restful api service
2017/12/04 Python
python2.7 json 转换日期的处理的示例
2018/03/07 Python
Python requests模块基础使用方法实例及高级应用(自动登陆,抓取网页源码)实例详解
2020/02/14 Python
Python多分支if语句的使用
2020/09/03 Python
纯CSS3实现自定义Tooltip边框涂鸦风格的教程
2014/11/05 HTML / CSS
澳大利亚床上用品、浴巾和家居用品购物网站:Bambury
2020/04/16 全球购物
某公司面试题
2012/03/05 面试题
社会学专业求职信
2014/02/24 职场文书
工程采购员岗位职责
2014/03/09 职场文书
离婚协议书范本样本
2014/08/19 职场文书
幼儿园六一儿童节活动方案
2014/08/26 职场文书
法学专业毕业实习自我鉴定2014
2014/09/27 职场文书
简易版租房协议书范本
2014/10/13 职场文书
中学教师师德师风承诺书
2015/04/28 职场文书
使用Nginx+Tomcat实现负载均衡的全过程
2022/05/30 Servers