【C语言题解】 | 965. 单值二叉树

965. 单值二叉树

提示:

  1. 给定树的节点数范围是 [1, 100]。
  2. 每个节点的值都是整数,范围为 [0, 99] 。
c 复制代码

这个题目我们通过分治思想来解题:

首先传入的是根节点

其次判断根节点是否有左子树和右子树,若存在则判断左右子树的值是否于根节点的值相同(不同则返回false,相同则继续)

c 复制代码
if(root->left && root->left->val != root->val
{
	return false;
}
if(root->right && root->right->val != root->val
{
	return false;
}

若正确,则继续向下递归,但是由于此题目要求返回true or flase,所以,我们需要返回

c 复制代码
return isUnivalTree(root->left) &&
    isUnivalTree(root->right);

因为是左右子树都必须满足,所以是 &&

代码:

c 复制代码
/**
 * 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);
}
相关推荐
睡醒了叭10 小时前
图像分割-传统算法-边缘分割
图像处理·opencv·算法·计算机视觉
AndrewHZ10 小时前
【图像处理基石】有哪些好用的图像去噪算法可以推荐一下么?
图像处理·深度学习·算法·计算机视觉·cv·噪声
一叶知秋0610 小时前
数据结构-什么是单向链表?
数据结构·链表
雪花desu10 小时前
【Hot100-Java中等】:字母异位词分组
java·算法·leetcode·哈希表
rchmin10 小时前
Redis Key过期删除策略详解
java·redis
秋邱10 小时前
Java抽象类与接口的核心区别:定义、特性与选型逻辑全解析
java·开发语言
Bdygsl10 小时前
数据结构 —— 栈
数据结构
Word码10 小时前
LeetCode283. 移动零(双指针精讲)
算法·leetcode·职场和发展
编程之路,妙趣横生10 小时前
数据结构(十一) 哈希表
数据结构
Ccuno10 小时前
Java中核心机制的概念
java·深度学习