二叉树中和为某一值的路径 python

  输入一颗二叉树的根节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。

  分析:我们可以先从最简单的情况开始考虑,最简单的情况就是二叉树只有一个根节点,判断根节点的值与期望值是否相同就ok了。二叉树稍微复杂一点就是根节点还有左右子节点,这时候的过程就要多一步,仍旧是先判断根节点的值与期望值,如果相等或者期望值更小,则不必继续向下判断,如果期望值更大,那么可以向下继续判断,此时的期望值变成了“期望值-根节点的值”,用新的期望值分别与左右子节点的值进行比较,因为左右子节点已经是叶节点,符合路径的定义,因此如果节点的值与新的期望值相等,就得到了答案,如果不相等,问题无解。现在推广到普通的二叉树,与上面的分析相同,就是一个不断更新期望值并与节点值比较的过程,这个过程是重复的,可以利用递归完成,下面来看一下具体代码。

  首先定义二叉树

class TreeNode:
    def __init__(self, x):
        self.val = x
        self.left = None
        self.right = None

  寻找路径的代码

#打印出二叉树中结点值的和为输入整数的所有路径。
    def FindPath(self, root, expectNumber):
        ans=[]#所有路径的集合
        if root==None:
            return ans
        def iterpath(root,expectNumber,dir=[]):
            if expectNumber>root.val:
                dir.append(root.val)#dir保存当前路径(不一定是符合要求的路径)
                #分别在左右子树中寻找并更新期望值
                if root.left!=None:
                    iterpath(root.left,expectNumber-root.val,dir)
                if root.right!=None:
                    iterpath(root.right,expectNumber-root.val,dir)
            elif expectNumber==root.val:
                dir.append(root.val)
                if root.right==None and root.left==None:#如果节点的值与期望值相同,则判断节点是否为叶子结点,如果是叶子结点则是符合条件的路径
                    tmp=dir[:]
                    ans.append(tmp)
            else:
                dir.append(0)
            dir.pop()#!!!!!!!!!!!!!
        iterpath(root,expectNumber)
        return ans

代码中有一个地方要注意,dir.pop()这一句,我已经用感叹号标识出来,这是必须要有的。原因是这样的,我们先来看一下这句什么时候会被执行,在判断节点值与期望值的大小关系时,有三种情况,如果期望值大于节点值,则会递归调用函数继续判断;如果是相等,则判断节点是否为叶子节点;如果期望值小于节点值,也有相应的操作。因此,在当前路径结束或者已经发现当前路径不符合要求时,会直接执行pop操作,pop操作的目的就是让dir从当前节点重新回到其父亲节点,然后去判断另一棵子树。如果不执行pop操作,dir会保存经过的所有的节点,就不是一条正常的路径了。因此,当期望值小于节点值时,dir仍旧会执行一次append操作,就是因为后面会把这个值pop出去。

原文地址:https://www.cnblogs.com/bambipai/p/9901965.html

时间: 2024-11-10 01:23:41

二叉树中和为某一值的路径 python的相关文章

24.二叉树中和为某一值的路径(python)

题目描述 输入一颗二叉树的跟节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径.(注意: 在返回值的list中,数组长度大的数组靠前) 1 import copy 2 class Solution: 3 # 返回二维列表,内部每个列表表示找到的路径 4 def FindPath(self, root, expectNumber): 5 # write code here 6 if root == None: 7 ret

二叉树中和为某一值的路径-剑指Offer

二叉树中和为某一值的路径 题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 思路 用栈来存储二叉树的路径,遍历到叶子结点就判断是否总和为target,是的话打印,若不是叶子结点,那继续遍历左右子树 注意:打印完后返回父结点时要弹出栈顶的叶子结点,并且总和减去该值 注意:打印路径时要遍历栈 代码 import java.util.ArrayList; import java.util.Stack;

打印二叉树中和为某一值的路径

输入一个二叉树,查找该树的所有路径(从根结点到叶结点的通路),并返回和(路径上所有结点值的和)为某一指定值的路径. 1 /////////////二叉树中和为某一值的路径///////////////////// 2 void FindPath(BinaryTreeNode* pRoot ,int expectedSum ,vector<int>& path ,int currentSum) 3 { 4 if (pRoot == NULL) 5 { 6 return; 7 } 8 cu

23.二叉树中和为某一值的路径

二叉树中和为某一值的路径 参与人数:2929时间限制:1秒空间限制:32768K 算法知识视频讲解 题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 牛客网不给测试用例让我感到很迷惑啊..再次提醒自己,vector是否为空用vector.empty()判断! // 24.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <v

LeetCode | 面试题34. 二叉树中和为某一值的路径【剑指Offer】【Python】

LeetCode 面试题34. 二叉树中和为某一值的路径[剑指Offer][Medium][Python][回溯] 问题 力扣 输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶节点所经过的节点形成一条路径. 示例: 给定如下二叉树,以及目标和 sum = 22, 5 / 4 8 / / 11 13 4 / \ / 7 2 5 1 返回: [ [5,4,11,2], [5,8,4,5] ] 提示: 节点总数 <= 10000 注意:本题与主站 1

二叉树中和为某一值的路径——25

输入一个二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 如上图的二叉树,当输入根结点和一个数值12的时候,就有两条路径"1->2->4->5"和"1->3->8",如果存在,就输出上述路径,如果没有任何一条路径满足就不输出路径并提示: 首先,路径一定是从根结点开始到某个叶子结点结束,这才是一条路径,因此,应该最先访问的就是根结点,而在二叉树的先中后序遍历中只有先

【剑指Offer】二叉树中和为某一值的路径

问题描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 算法分析 如果 root 等于 输入数,将root放在返回数组里返回:如果root大于输入数,返回空值: 如果root小于输入数,将root放在数组里,输入数自减root,一同随root的子树递归: 如果输入数为0了且左右子树都为空,即为叶子节点,则这条路径可行,返回数组: 如果 root 没有子树了,同时输入数还没为0,说明此路不通,返回NUL

剑指Offer面试题25(Java版):二叉树中和为某一值的路径

题目:输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶结点所经过的所有的结点形成一条路径. 如下图,输入二叉树和整数22,则打印出两条路径,第一条路径包含结点10,12,第二条路径包含的结点为10,5,7. 一般的数据结构和算法的教材都没有介绍树的路径,因此对大多数应聘者而言,这是一个新概念,也就很难一下子想出完整的解题思路.这个时候我们可以试着从一两个具体的例子入手,找到规律. 以图中的二叉树为例分析,由于路径是从根节点出发到叶结点,也就是说

24、二叉树中和为某一值的路径

一.题目 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 二.解法 1 public class Solution { 2 //存储所有的路径 3 private ArrayList<ArrayList<Integer>> listall = new ArrayList<ArrayList<Integer>>(); 4 //存储一条路径 5 private Arra