代码随想录 | Day19 | 复习二叉树所写部分

代码随想录 | Day19 | 复习二叉树所写部分

Day 16

对称二叉树记忆不清晰,只有个大概的轮廓,但后序遍历(严格来说并不是)还是可以写出,层序遍历不记得方法

Day17

111. 二叉树的最小深度 - 力扣(LeetCode)

最小深度不够熟悉,方法也忘记了,也写错了,后续需要再次复习

Day18

222. 完全二叉树的节点个数 - 力扣(LeetCode)

利用二叉树性质的做法需要复习

110. 平衡二叉树 - 力扣(LeetCode)

c++ 复制代码
class Solution {
public:
    bool flag=true;
    int backtracking(TreeNode *t)
    {
        if(t==nullptr)
            return 0;
        int l=1+backtracking(t->left);
        int r=1+backtracking(t->right);
        if(abs(l-r)>1)
            flag=false;
        return max(l,r);
    }
    bool isBalanced(TreeNode* root) {
        int d=backtracking(root);
        return flag;
    }
};

复习时写出的是这样的代码,也可以通过

关键点就是求出每个结点的左右子树的高度,差不超过1

注意是每个结点,而不是只有根结点

相关推荐
愈努力俞幸运11 分钟前
c++ 头文件
开发语言·c++
永日4567018 分钟前
学习日记-day24-6.8
开发语言·学习·php
安和昂20 分钟前
【iOS】 Block再学习
学习·ios·cocoa
pop_xiaoli22 分钟前
OC学习—命名规范
学习·ios
jackson凌23 分钟前
【Java学习笔记】String类(重点)
java·笔记·学习
~山有木兮23 分钟前
C++设计模式 - 单例模式
c++·单例模式·设计模式
行云流水剑31 分钟前
【学习记录】在 Ubuntu 中将新硬盘挂载到 /home 目录的完整指南
服务器·学习·ubuntu
vijaycc35 分钟前
python学习打卡day47
学习
十五年专注C++开发35 分钟前
CMake基础:gcc/g++编译选项详解
开发语言·c++·gcc·g++
MSTcheng.42 分钟前
【数据结构】顺序表和链表详解(下)
数据结构·链表