力扣——单值二叉树(C语言)

1.题目:

如果二叉树每个节点都具有相同的值,那么该二叉树就是单值 二叉树。只有给定的树是单值二叉树时,才返回 true;否则返回 false

2.原理:

这里运用递归,向下递归,判断左右节点是否相等,不相等返回false,直到空节点,这里最后return里是&&,所以只要遇到false,最终回退到根节点也是false,也就不是单值二叉树,反之如果回退回来一直都相等,回退true,就是单值二叉树。

3.整体代码:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
bool isUnivalTree(struct TreeNode* root) {
    if(root==NULL)
    {
        return true;
    }
    if(root->left&&root->left->val!=root->val)
    {
        return false;
    }
    if(root->right&&root->right->val!=root->val)
    {
        return false;
    }
    return isUnivalTree(root->left)&&isUnivalTree(root->right);
}
相关推荐
_深海凉_5 分钟前
LeetCode热题100-回文链表
算法·leetcode·链表
小雅痞8 分钟前
[Java][Leetcode middle] 54. 螺旋矩阵
java·leetcode·矩阵
星恒随风10 分钟前
C语言链表详解:从单链表到双向链表
c语言·开发语言·链表
pursuit_csdn11 分钟前
力扣周赛 501
算法·leetcode·职场和发展
努力d小白13 分钟前
leetcode70.爬楼梯
算法
AbandonForce13 分钟前
LeetCode 滑动窗口个人思路详解
算法·leetcode·职场和发展
bnmoel15 分钟前
数据结构深度剖析顺序表:结构、扩容与增删查改全解析
c语言·数据结构·算法·顺序表
Liangwei Lin15 分钟前
LeetCode 45. 跳跃游戏 II
数据结构·算法·leetcode
啦啦啦_999919 分钟前
4. 决策树剪枝
算法·决策树·剪枝
鹿角片ljp22 分钟前
全局哈希去重原理与数据集实践
算法·安全·哈希算法