【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);
}
相关推荐
贾斯汀玛尔斯2 分钟前
每天学一个算法--BM25(Okapi BM25)
算法
山甫aa19 分钟前
二叉树遍历----从零开始的数据结构
数据结构·c++·二叉树
Cat_Rocky24 分钟前
通过k8s实现单pod部署
java·容器·kubernetes
grant-ADAS29 分钟前
Overlay套刻测量
算法
老花眼猫32 分钟前
三角函数绘制椭圆和椭圆旋转
c语言·经验分享·青少年编程·课程设计
猿长大人33 分钟前
算法 | Douglas-Peucker 拯救“腰椎间盘突出的三角形”
算法
秋937 分钟前
Java AI编程工具全景解析:功能、收费与工单系统实战指南
java·开发语言·ai编程
瑶山37 分钟前
IDEA 配置Go语言开发环境、GOPATH传统 Go 项目导入
java·golang·intellij-idea
HackTorjan1 小时前
深度解析雪花算法及其高性能优化策略
人工智能·深度学习·算法·性能优化·dreamweaver
weixin_419658311 小时前
RabbitMQ 的高级特性
java·分布式·rabbitmq