剑指offer(C++)-JZ82:二叉树中和为某一值的路径(一)(数据结构-树)

简介: 剑指offer(C++)-JZ82:二叉树中和为某一值的路径(一)(数据结构-树)

题目描述:

给定一个二叉树root和一个值 sum ,判断是否有从根节点到叶子节点的节点值之和等于 sum 的路径。


1.该题路径定义为从树的根结点开始往下一直到叶子结点所经过的结点


2.叶子节点是指没有子节点的节点


3.路径只能从父节点到子节点,不能从子节点到父节点


4.总节点数目为n

例如:

给出如下的二叉树,sum=22,

返回true,因为存在一条路径 5→4→11→2的节点值之和为 22

数据范围1.树上的节点数满足0≤n≤10000

2.每 个节点的值都满足∣val∣≤1000

要求:空间复杂度O(n),时间复杂度 O(n)

进阶:空间复杂度 O(树的高度),时间复杂度 O(n)

示例1:

输入:

{5,4,8,1,11,#,9,#,#,2,7},22


返回值:

true

示例2:

输入:

{1,2},0


返回值:

false


解题思路:

本题考察数据结构树的使用,可运用stack栈后入先出的特性解题。


1)将根节点放入栈进入循环。


2)获取根节点的值,并弹出根节点,当左子树存在时,将左子树的数值叠加根节点的数值,并将左子树放入栈,右子树同理。


3)从栈顶取出节点,该节点应该是上一轮的右子树,以其为该轮的根,继续扫描其左右子树,若有则继续存入栈内。


4)当栈为空时,说明所有的结点都遍历过了,无结果则返回false。


5)当某一轮根结点的值与目标值一致且左右子树均无,则说明该节点是叶子节点,且符合要求,返回true完成。


该逻辑类似于前序遍历,无非是将过程中每个节点的值替换为对应路径值的和。

测试代码:

/**
 * struct TreeNode {
 *  int val;
 *  struct TreeNode *left;
 *  struct TreeNode *right;
 * };
 */
class Solution {
public:
    /**
     * 
     * @param root TreeNode类 
     * @param sum int整型 
     * @return bool布尔型
     */
    bool hasPathSum(TreeNode* root, int sum) {
        stack<TreeNode*> t;
        if(!root)
            return false;
        t.push(root);
        TreeNode* current;
        while(!t.empty())
        {
            current=t.top();
            t.pop();
            if(current->left)
            {
                current->left->val+=current->val;
                t.push(current->left);
            }
            if(current->right)
            {
                current->right->val+=current->val;
                t.push(current->right);
            }
            if(current->val==sum&&!current->left&&!current->right)
                return true;
        }
        return false;
    }
};


相关文章
|
1月前
|
存储 算法 C语言
"揭秘C语言中的王者之树——红黑树:一场数据结构与算法的华丽舞蹈,让你的程序效率飙升,直击性能巅峰!"
【8月更文挑战第20天】红黑树是自平衡二叉查找树,通过旋转和重着色保持平衡,确保高效执行插入、删除和查找操作,时间复杂度为O(log n)。本文介绍红黑树的基本属性、存储结构及其C语言实现。红黑树遵循五项基本规则以保持平衡状态。在C语言中,节点包含数据、颜色、父节点和子节点指针。文章提供了一个示例代码框架,用于创建节点、插入节点并执行必要的修复操作以维护红黑树的特性。
49 1
|
1月前
|
安全 编译器 C语言
【C++数据结构】string的模拟实现
【C++数据结构】string的模拟实现
|
9天前
|
C语言
数据结构基础详解(C语言):图的基本概念_无向图_有向图_子图_生成树_生成森林_完全图
本文介绍了图的基本概念,包括图的定义、无向图与有向图、简单图与多重图等,并解释了顶点度、路径、连通性等相关术语。此外还讨论了子图、生成树、带权图及几种特殊形态的图,如完全图和树等。通过这些概念,读者可以更好地理解图论的基础知识。
|
11天前
|
存储 算法 C语言
数据结构基础详解(C语言): 二叉树的遍历_线索二叉树_树的存储结构_树与森林详解
本文从二叉树遍历入手,详细介绍了先序、中序和后序遍历方法,并探讨了如何构建二叉树及线索二叉树的概念。接着,文章讲解了树和森林的存储结构,特别是如何将树与森林转换为二叉树形式,以便利用二叉树的遍历方法。最后,讨论了树和森林的遍历算法,包括先根、后根和层次遍历。通过这些内容,读者可以全面了解二叉树及其相关概念。
|
11天前
|
存储 机器学习/深度学习 C语言
数据结构基础详解(C语言): 树与二叉树的基本类型与存储结构详解
本文介绍了树和二叉树的基本概念及性质。树是由节点组成的层次结构,其中节点的度为其分支数量,树的度为树中最大节点度数。二叉树是一种特殊的树,其节点最多有两个子节点,具有多种性质,如叶子节点数与度为2的节点数之间的关系。此外,还介绍了二叉树的不同形态,包括满二叉树、完全二叉树、二叉排序树和平衡二叉树,并探讨了二叉树的顺序存储和链式存储结构。
|
11天前
|
存储 C语言
数据结构基础详解(C语言): 树与二叉树的应用_哈夫曼树与哈夫曼曼编码_并查集_二叉排序树_平衡二叉树
本文详细介绍了树与二叉树的应用,涵盖哈夫曼树与哈夫曼编码、并查集以及二叉排序树等内容。首先讲解了哈夫曼树的构造方法及其在数据压缩中的应用;接着介绍了并查集的基本概念、存储结构及优化方法;随后探讨了二叉排序树的定义、查找、插入和删除操作;最后阐述了平衡二叉树的概念及其在保证树平衡状态下的插入和删除操作。通过本文,读者可以全面了解树与二叉树在实际问题中的应用技巧和优化策略。
|
20天前
|
存储 C++
【C++】AVL树
AVL树是一种自平衡二叉搜索树:它以苏联科学家Georgy Adelson-Velsky和Evgenii Landis的名字命名。
16 2
|
1月前
|
存储 算法 Linux
【数据结构】树、二叉树与堆(长期维护)(1)
【数据结构】树、二叉树与堆(长期维护)(1)
|
1月前
|
算法
【数据结构】树、二叉树与堆(长期维护)(2)
【数据结构】树、二叉树与堆(长期维护)(2)
【数据结构】树、二叉树与堆(长期维护)(2)
|
1月前
|
C++ 容器
【数据结构】AVL树
【数据结构】AVL树