leetcode二叉树

下面的两个题呢是比较类似的所以放在一起讲,更好的理解起来。

https://leetcode.cn/problems/same-tree/description/

这个题就是比较两颗树是不是一样的,这个其实看起来就只要比较当前节点,我们分析成子问题就是判断两颗树当前节点是不是一致的,比如p和q的val还有就是为空的时候我们,这样我们的代码其实就写好了。

c 复制代码
bool isSameTree(struct TreeNode* p, struct TreeNode* q) {
    if(p == NULL && q == NULL)
    {
        return true;
    }
    if(p == NULL || q == NULL)
    {
        return false;
    }
    if(p->val != q->val)
    {
        return false;
    }

    return isSameTree(p->left, q->left)
    && isSameTree(p->right, q->right);
}

所以这个题目时比较简单的,分析成子问题只要看当前的子节点就行了,下面马上跟上一个类似的就是
https://leetcode.cn/problems/univalued-binary-tree/description/

这个题可以分成的子问题就是我们来判断父亲节点和孩子节点是不是相同的子问题,但是还是需要考虑的一个问题就是空这个问题,因为如果是空的话就需要返回的是true,空了还玩个鸡毛啊哈哈哈哈,比如我们一个节点的时候左右孩子都是空,那我们这要也是最后要输出true的,有了这样的分析,我们可以把代码写成这样。

c 复制代码
bool isUnivalTree(struct TreeNode* root) {
    if(root == NULL)
    {
        return true;
    }
    
    if(root->left != NULL && root->left->val != root->val)
    {
        return false;
    }
    if(root->right != NULL && root->right->val != root->val)
    {
        return false;
    }
    return isUnivalTree(root->left) && isUnivalTree(root->right);
}

把三道题分了两篇文章哈哈哈哈,主要是为了那个流量扶持,但是我保证我没有水文章,最近又期末考试了,要忙起来了。

相关推荐
一水鉴天14 分钟前
整体设计 逻辑系统程序 之34七层网络的中台架构设计及链路对应讨论(含 CFR 规则与理 / 事代理界定)
人工智能·算法·公共逻辑
DuHz17 分钟前
C程序中的数组与指针共生关系
linux·c语言·开发语言·嵌入式硬件·算法
而后笑面对17 分钟前
力扣2025.10.19每日一题
算法·leetcode·职场和发展
·白小白35 分钟前
力扣(LeetCode) ——11.盛水最多的容器(C++)
c++·算法·leetcode
007php0071 小时前
百度面试题解析:Zookeeper、ArrayList、生产者消费者模型及多线程(二)
java·分布式·zookeeper·云原生·职场和发展·eureka·java-zookeeper
沐浴露z2 小时前
【JVM】详解 垃圾回收
java·jvm·算法
代码欢乐豆2 小时前
编译原理机测客观题(7)优化和代码生成练习题
数据结构·算法·编译原理
程序员小远3 小时前
软件测试之压力测试详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·压力测试
Scc_hy3 小时前
强化学习_Paper_2000_Eligibility Traces for Off-Policy Policy Evaluation
人工智能·深度学习·算法·强化学习·rl
leke20034 小时前
2025年10月17日
算法