LeetCode 110.平衡二叉树

分析1.0

求左子树高度和右子树高度,若高度差>1,则返回false,所以我递归了两遍

class Solution {
public boolean isBalanced(TreeNode root) {
if(root == null){
return true;
}
int left = postOrder(root.left);
int right = postOrder(root.right);
if(Math.abs(left-right)>1){
return false;
}
return true;
} public int postOrder(TreeNode p){
if(p == null){
return 0;
}
int left = postOrder(p.left);
int right = postOrder(p.right);
return Math.max(left,right)+1;
}
}

失误

若在遍历过程中已经发现高度不平衡了,那这时其实就该返回false,但是返回结果类型是高度int,只能用特殊值来指代这种情况,遍历过程中发现不平衡了就返回-1,发现当前节点是-1了就该返回-1

分析2.0

class Solution {
public boolean isBalanced(TreeNode root) {
if(root == null){
return true;
}
return postOrder(root) == -1 ? false : true;
} public int postOrder(TreeNode p){
if(p == null){
return 0;
}
int left = postOrder(p.left);
if(left == -1) return -1;
int right = postOrder(p.right);
if(right == -1) return -1;
if(Math.abs(left-right)>1) {
return -1;
}
return Math.max(left,right)+1;
}
}

LeetCode 257. 二叉树的所有路径

分析1.0

模拟访问路径的过程,从根节点访问到最左叶节点 ,访问过程中不断push经过的节点

逻辑:

path加入当前节点、如果当前节点是叶节点,添加path,返回,删除当前加入的节点;如果是左节点或右节点,进入递归;

关键在于递归时什么时候删除访问过的节点,访问左节点完了删除左节点,访问右节点完了删除右节点,访问自己完了,删除自己

class Solution {
List<String> res = new ArrayList();
List<Integer> path = new ArrayList();
public List<String> binaryTreePaths(TreeNode root) {
preOrder(root);
// 这里也可以看做是一次递归 递归结束后才能删除本节点
// path.remove(path.size() - 1);
System.out.println("path为-----"+path);
return res;
}
public void preOrder(TreeNode p){
// 对当前节点进行操作 节点的数目范围在[1,100] 肯定有节点,不必判空
path.add(p.val);
// 到达叶节点 遍历完一条路径 此条路径加入当前节点后回溯
if(p.left == null && p.right == null){
//System.out.println("当前叶子节点"+p.val);
StringBuilder sb = new StringBuilder();
for(int i = 0; i < path.size() - 1; i++){
sb.append(path.get(i)).append("->");
}
res.add(sb.append(path.get(path.size() - 1)).toString());
return;
}
// 遍历左子树
if(p.left != null){
//加入节点
//System.out.println(p.left.val);
preOrder(p.left);
// 删除节点
//System.out.println("删除的节点"+path.get(path.size()-1));
// 这里也要回溯删除加入的节点和->
path.remove(path.size() - 1);
}
// 遍历右子树
if(p.right != null){
preOrder(p.right);
// 这里也要回溯删除加入的节点和->
path.remove(path.size() - 1);
}
//path.remove(path.size() - 1); //这里不能再删除了 前面递归结束已经删除一次了
}
}

LeetCode 404.左叶子之和

分析1.0

递归,但是递归的过程中要判断一个节点是否为左叶子

失误 

光想着节点本身了,但是光凭借节点自身的信息无发判断一个节点是左孩子还是右孩子,左右孩子是通过父节点指针来确定的,叶子节点则再加一个限制

分析2.0

遍历节点,if当前节点cur为空,返回,if左孩子的左右节点都为null,则cui.left为左叶子

if(root.left != null && root.left.left == null && root.left.right == null) 访问节点保证节点非null

class Solution {
int sum = 0;
public int sumOfLeftLeaves(TreeNode root) {
preOrder(root);
return sum;
} public void preOrder(TreeNode root){
if(root == null){
return;
}
if(root.left != null && root.left.left == null && root.left.right == null){
sum+=root.left.val;
}
preOrder(root.left);
preOrder(root.right);
}
}

总结

  1. 二叉树节点的深度:指从根节点到该节点的最长简单路径边的条数。
  2. 二叉树节点的高度:指从该节点到叶子节点的最长简单路径边的条数。
  3. 回溯要和递归永远在一起,递归后一定要回溯,必须在同一个代码块中
  4. 当前节点为空,直接返回,不用再考虑left right节点了
  5. 操作某个节点,一定要保证这个节点不为空
  6. 方法只执行一次,可以看做只递归一次; 递归主体逻辑,结束条件,返回参数+形式参数,先判是结束递归,还是先执行递归逻辑,递归后又该如何做

常用变量名增量更新

size、val、ans、cnt、cur、pre、next、left、right、index、gap、tar、res、src、len、start、end、flag、ch、var

 

代码随想录算法训练营day17 | leetcode ● 110.平衡二叉树 ● 257. 二叉树的所有路径 ● 404.左叶子之和的更多相关文章

  1. LeetCode 404. 左叶子之和(Sum of Left Leaves)

    404. 左叶子之和 404. Sum of Left Leaves LeetCode404. Sum of Left Leaves 题目描述 计算给定二叉树的所有左叶子之和. 示例: 3 / \ 9 ...

  2. [LeetCode]404. 左叶子之和(递归)、938. 二叉搜索树的范围和(递归)(BST)

    题目 404. 左叶子之和 如题 题解 类似树的遍历的递归 注意一定要是叶子结点 代码 class Solution { public int sumOfLeftLeaves(TreeNode roo ...

  3. Java实现 LeetCode 404 左叶子之和

    404. 左叶子之和 计算给定二叉树的所有左叶子之和. 示例: 3 / \ 9 20 / \ 15 7 在这个二叉树中,有两个左叶子,分别是 9 和 15,所以返回 24 /** * Definiti ...

  4. 【LeetCode】404. 左叶子之和

    404. 左叶子之和 知识点:二叉树 题目描述 计算给定二叉树的所有左叶子之和.. 示例 3 / \ 9 20 / \ 15 7 在这个二叉树中,有两个左叶子,分别是 9 和 15,所以返回 24 解 ...

  5. LeetCode 110. 平衡二叉树(Balanced Binary Tree) 15

    110. 平衡二叉树 110. Balanced Binary Tree 题目描述 给定一个二叉树,判断它是否是高度平衡的二叉树. 本题中,一棵高度平衡二叉树定义为: 一个二叉树每个节点的左右两个子树 ...

  6. Java实现 LeetCode 110 平衡二叉树

    110. 平衡二叉树 给定一个二叉树,判断它是否是高度平衡的二叉树. 本题中,一棵高度平衡二叉树定义为: 一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过1. 示例 1: 给定二叉树 [3,9 ...

  7. LeetCode 110.平衡二叉树(C++)

    给定一个二叉树,判断它是否是高度平衡的二叉树. 本题中,一棵高度平衡二叉树定义为: 一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过1. 示例 1: 给定二叉树 [3,9,20,null,nu ...

  8. LeetCode 257 二叉树的所有路径

    题目: 给定一个二叉树,返回所有从根节点到叶子节点的路径. 说明: 叶子节点是指没有子节点的节点. 示例: 输入: 1 / \ 2 3 \ 5 输出: ["1->2->5&quo ...

  9. [LeetCode 110] - 平衡二叉树 (Balanced Binary Tree)

    问题 给出一棵二叉树,判断它是否在高度上是平衡的. 对于本问题,高度上平衡的二叉树定义为:每个节点的两棵子树的深度差永远不大于1的一棵二叉树. 初始思路 根据定义,思路应该比较直接:递归计算每个节点左 ...

  10. 【leetcode 简单】 第九十四题 左叶子之和

    计算给定二叉树的所有左叶子之和. 示例: 3 / \ 9 20 / \ 15 7 在这个二叉树中,有两个左叶子,分别是 9 和 15,所以返回 24 # Definition for a binary ...

随机推荐

  1. WeakHashMap 和 HashMap 的区别是什么,何时使用?

    本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 提问. 前言 大家好,我是小彭. 在之前的文章里,我们聊到了 Java 标准库中 HashMap 与 LinkedH ...

  2. Java开发学习(四十六)----MyBatisPlus新增语句之id生成策略控制及其简化配置

    在前面有一篇博客:Java开发学习(四十一)----MyBatisPlus标准数据层(增删查改分页)开发,我们在新增的时候留了一个问题,就是新增成功后,主键ID是一个很长串的内容. 我们更想要的是按照 ...

  3. angr_ctf——从0学习angr(三):Hook与路径爆炸

    路径爆炸 之前说过,angr在处理分支时,采取统统收集的策略,因此每当遇见一个分支,angr的路径数量就会乘2,这是一种指数增长,也就是所说的路径爆炸. 以下是路径爆炸的一个例子: char buff ...

  4. DHorse日志收集原理

    实现原理 基于k8s的日志收集主要有两种方案,一是使用daemoset,另一种是基于sidecar.两种方式各有优缺点,目前DHorse是基于daemoset实现的.如图1所示: 图1 在每个k8s集 ...

  5. python里面一些零碎知识点

    1. Python中反斜杠可以用在一行结尾做续行符使用. 2. pytorch中,一般来说如果对tensor的一个函数后加上了下划线,则表明这是一个in-place类型.in-place类型是指,当在 ...

  6. [OpenCV实战]1 基于深度学习识别人脸性别和年龄

    目录 1基于CNN的性别分类建模原理 1.1 人脸识别 1.2 性别预测 1.3 年龄预测 1.4 结果 2 代码 参考 本教程中,我们将讨论应用于面部的深层学习的有趣应用.我们将估计年龄,并从单个图 ...

  7. 数位排序【第十三届蓝桥杯省赛C++C组】

    数位排序 小蓝对一个数的数位之和很感兴趣,今天他要按照数位之和给数排序. 当两个数各个数位之和不同时,将数位和较小的排在前面,当数位之和相等时,将数值小的排在前面. 例如,\(2022\) 排在 \( ...

  8. LVGL 中图片使用问题

    此笔记主要是记录在 LVGL 中使用图片的几种方式,以及使用过程中遇到的问题.最近在 ARM linux 中使用 LVGL 时,发现加载图片变得很卡,一开始还好,当连续加载的图片变多后,特别是动画的过 ...

  9. SOFAJRaft源码阅读-ShutdownHook如何优雅的停机

    Java程序经常会遇到进程挂掉的情况,一些状态没有正确的保存下来,这时候就需要在JVM关掉的时候执行一些清理现场的代码.JAVA中的ShutdownHook提供了比较好的方案.而在SOFAJRaft- ...

  10. 今天学到的新知识--自己的电脑可以像Github Pages、码云 Pages一样发布静态资源

    大佬教我的,感觉这个很神奇哦 假设下面这个路径是我的本地电脑静态资源路径 打开powershell窗口 然后按照下图的样子执行命令 复制网址就可以访问啦 然后可以通过 https://iplocati ...