当前位置:首页 > 力扣 > 力扣965题深度解析:单值二叉树的判断技巧

力扣965题深度解析:单值二叉树的判断技巧

2个月前 (05-31)


力扣965题深度解析:单值二叉树的判断技巧 二叉树 深搜 深度优先搜索 递归 分治算法 C++ 算法 第1张

重新解读题目 

判断一棵二叉树是否为“单值二叉”,即所有节点的值是否完全相同。题目看似简单,实则考验对树结构递归特性的理解。若一棵树的所有节点值相同,其必然满足:根节点与左右子树的值一致,且左右子树各自也为单值二叉树。这一特性,为递归解法提供了清晰的切入点。


解题思路与过程 

用递归分治策略,将大问题拆解为小问题:若一棵树是单值二叉树,其左右子树必须同样是单值二叉树,且所有子节点的值与根节点相等。

1. 边界条件:当树为空或仅含根节点时,直接返回true(空树视为单值,单个节点自然满足)。

2. 递归判定: 

        递归调用左、右子树,判断其是否为单值树(LAndR变量)。 

        若左右子树均合法,进一步检查根节点与左右子节点的值是否一致(RootAndLAndR变量)。 

        通过逻辑与(LAndR && RootAndLAndR)综合子树结果与根节点关系,最终返回结论。 


带注释的代码解析

class Solution {
public:
    bool isUnivalTree(TreeNode* root) {
        // 空树或仅含根节点,直接返回true
        if (!root || (!root->left &&!root->right))  
            return true;  
        
        // 递归判断左右子树是否为单值树
        bool LAndR = isUnivalTree(root->left) && isUnivalTree(root->right);  
        // 判断根节点与左右子节点是否值相同
        bool RootAndLAndR = true;  
        if (root->left && root->right)  
            RootAndLAndR = (root->val == root->left->val && root->val == root->right->val);  
        else if (root->left)  
            RootAndLAndR = (root->val == root->left->val);  
        else  
            RootAndLAndR = (root->val == root->right->val);  
        
        // 综合子树结果与根节点关系
        return LAndR && RootAndLAndR;  
    }
};


参考:力扣965题 解题思路和步骤 C++代码实现,力扣题库答案在哪里

原创内容 转载请注明出处

分享给朋友:

相关文章

力扣LCR182:字符串操作三连 从基础拼接到底层指针优化

力扣LCR182:字符串操作三连 从基础拼接到底层指针优化

题目重解需要将密码字符串从第target个字符开始进行重新排列,形成新的动态密码。例如输入"password"和target=3,结果应为"swordpas"。...

力扣1137题:动态规划解泰波那契数 高效求解第N项的秘密

力扣1137题:动态规划解泰波那契数 高效求解第N项的秘密

一:重新解读题目泰波那契数列是一个充满数学趣味的递推序列:从第3项开始,每个数均为前三个数的和(即Tₙ₊₃ = Tₙ + Tₙ₊₁ + Tₙ₊₂)。当给定整数n时,需要高效计算出第n项的值。面对此类递...

IOI 1994 洛谷1216:如何用O(1)空间解决数字三角形问题?附代码实现

IOI 1994 洛谷1216:如何用O(1)空间解决数字三角形问题?附代码实现

题目重解:数字三角形是一个经典的动态规划问题,给定一个由数字组成的三角形结构,从顶部出发,每次可以移动到下方相邻的数字,最终到达底部。我们需要找到一条路径,使得路径上经过的数字总和最大。这个问题可以很...

力扣第44题:寻找两个正序数组的中位数 - 合并排序解法详解

力扣第44题:寻找两个正序数组的中位数 - 合并排序解法详解

内容简介本文详细解析了力扣第44题"寻找两个正序数组的中位数"的合并排序解法。通过双指针技术合并两个有序数组,然后直接计算合并后数组的中位数。虽然时间复杂度为O(m+n),但这种方...

牛客13279题解:利用递归与深度优先搜索计算树的最大高度(附完整代码)

牛客13279题解:利用递归与深度优先搜索计算树的最大高度(附完整代码)

一、题目解读牛客13279题要求计算给定树的最大高度。题目输入一棵以邻接表形式表示的树(节点从0开始编号),需要输出从根节点到最深叶节点的最长路径长度。树的结构由n个节点和n-1条边构成,保证为连通无...

标题:洛谷B3617题解析:八进制转十六进制算法实现与优化(附AC100代码)

标题:洛谷B3617题解析:八进制转十六进制算法实现与优化(附AC100代码)

一、题目解读洛谷B3617题要求将输入的八进制字符串转换为十六进制表示。题目需处理大数场景,且对输入合法性有明确限制(长度不超过1000,仅包含0-7字符)。由于八进制与十六进制无法直接转换,需借助十...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。