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

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

5个月前 (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++代码实现,力扣题库答案在哪里

原创内容 转载请注明出处

分享给朋友:

相关文章

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

题目解读‌我们面对的是一个典型的图论问题:给定一个城市的连接矩阵,需要计算其中相互连通的城市群(省份)数量。这个问题可以抽象为无向图中的连通分量计算,每个城市代表图中的一个节点,城市之间的连接关系代表...

IOI 1994 洛谷1216:如何用动态规划高效解决数字三角形问题?附完整代码解析

IOI 1994 洛谷1216:如何用动态规划高效解决数字三角形问题?附完整代码解析

题目重解给定一个由数字组成的三角形结构,从顶部出发,每次可以移动到下方相邻的数字,最终到达底部。我们的目标是找到一条路径,使得路径上经过的数字总和最大。这个问题在实际中有许多应用场景,如最优路径规划、...

手搓顺序表类代码注释与详解:从零实现动态数组(新手教程)

一、简介和特点顺序表(Sequential List)是数据结构中基础的一种线性表,其特点是将数据元素存储在连续的内存空间中。通过数组实现,支持随机访问(即通过索引直接访问元素),适用于频繁随机读取的...

【CSP-S 2019】括号树(洛谷P5658)解题报告:栈+DFS+异或优化详解

【CSP-S 2019】括号树(洛谷P5658)解题报告:栈+DFS+异或优化详解

一、题目解读括号树问题(洛谷P5658)要求处理一个由括号序列转化的树结构:每个节点表示一个括号,'('为子节点,')'为父节点。题目给定一棵n个节点的树,需计算每个节...

洛谷1656题解:基于Tarjan算法求解割边问题(附代码与详细步骤)

洛谷1656题解:基于Tarjan算法求解割边问题(附代码与详细步骤)

一、题目解读洛谷1656题要求在无向图中找出所有割边(即删除后导致图不连通的边)。题目核心在于判断图的连通性,并识别哪些边是“桥”。需理解图论中的连通分量概念,以及如何通过算法高效定位割边。二、解题思...

洛谷P2190题解:铁路售票系统车厢计算(差分数组+前缀和优化)

洛谷P2190题解:铁路售票系统车厢计算(差分数组+前缀和优化)

一、题目解读洛谷P2190题要求解决铁路售票系统中的车厢数量计算问题。题目给定n个车站和m条订票申请,每条申请包含区间[x,y)及乘客数z。需要计算在不超载的情况下(每节车厢最多36人),满足所有乘客...

发表评论

访客

看不清,换一张

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