五:二叉树中和为某一直的路径

例如:求和为22的路径

求值步骤

规律:当用前序遍历的方式访问到某一节点时,我们把这个节点添加到路径上,并累加该节点的值,如果该节点为叶子节点并且路径中节点值的和刚好等于输入的整数,则当前的路径符合要求,我们把它打印出来。如果当前节点不是叶节点,则继续访问它的子节点。当前节点访问结束后,递归函数将自动回到它的父节点。因此我们在函数退出之前要在路径上删除当前节点,并减去当前节点的值,以确保返回父节点时路径刚好是从根节点到父节点的路径。不难看出保存路径的数据结构实际上是一个栈,因为路径要与递归调用状态一致,而递归调用的本质就是一个压栈和出栈的过程。

但是由于使用栈不便于路径的输出,所以可以借助于vector的push_back和pop_back在尾部增删路径节点

代码如下:

voidFindPath

(

BinaryTreeNode*   pRoot,

int               expectedSum,

std::vector<int>& path,

int&              currentSum

)

{

currentSum += pRoot->m_nValue;

path.push_back(pRoot->m_nValue);

//
如果是叶结点,并且路径上结点的和等于输入的值

//
打印出这条路径

bool isLeaf = pRoot->m_pLeft == NULL&& pRoot->m_pRight == NULL;

if(currentSum == expectedSum &&isLeaf)

{

printf("A path is found: ");

std::vector<int>::iterator iter = path.begin();

for(; iter != path.end(); ++ iter)

printf("%d\t", *iter);

printf("\n");

}

//
如果不是叶结点,则遍历它的子结点

if(pRoot->m_pLeft != NULL)

FindPath(pRoot->m_pLeft,expectedSum, path, currentSum);

if(pRoot->m_pRight != NULL)

FindPath(pRoot->m_pRight,expectedSum, path, currentSum);

//
在返回到父结点之前,在路径上删除当前结点,

//
并在currentSum中减去当前结点的值

currentSum -= pRoot->m_nValue;

path.pop_back();

}

voidCallFindPath(BinaryTreeNode* pRoot, int expectedSum)

{

if(pRoot == NULL)

return;

std::vector<int> path;

int currentSum = 0;

FindPath(pRoot, expectedSum, path,currentSum);

}

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-21 10:02:11

五:二叉树中和为某一直的路径的相关文章

二叉树中和为某一值得路径 java实现

本题来自<剑指offer> 路径为从根节点到叶节点一条路径,路径经过的各节点数值之和等于某一给定数值,则打印路径上的节点 因为需要打印满足条件的路径节点信息和各节点之和,需要栈记录经过的节点,和一个保存数值之和的变量 用前序遍历方法,可以首先访问节点,然后将节点入栈,并将数值和之前入栈的节点值相加 如果当前之和否满足给定值,判断当前节点是否叶节点,是则打印路径信息 判断节点左右孩子是否为空,递归调用 在调用完,返回时要将入栈的值出栈(此时栈中节点只到父节点),和变量也要变回调用之前的状态 1

剑指offer 二叉树中和为某一值得路径

class Solution { public: void recur(TreeNode* root, const int expectNumber, int curr, vector<vector<int>>& res, vector<int>& path){ path.push_back(root->val); curr += root->val; bool isLeaf = (root->left == nullptr &

二叉树中和为某一值的路径-剑指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

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

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

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

输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. import java.util.ArrayList; /** public class TreeNode { int val = 0; TreeNode left = null; TreeNode right = null; public TreeNode(int val) { this.val = val; } } */ import java.uti

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

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