算法第十五天|110.平衡二叉树 |257. 二叉树的所有路径 |404.左叶子之和

文章介绍了三种二叉树问题的解决方案:1)平衡二叉树的高度差计算采用后续遍历;2)二叉树所有路径的获取利用前序遍历与递归;3)求左叶子节点之和需借助后序遍历判断。每种方法都结合了递归和特定的遍历策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

110.平衡二叉树

平衡二叉树指的是一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。题目要求的是比较高度,必然是使用后续遍历,计算两个数之差(绝对值)使用函数Math.abs(int num1 - int num2),本题采用后续遍历的方法,递归遍历,代码如下

257. 二叉树的所有路径

第一次遇到题目,看完题解后又实现了一遍,思路是使用前序遍历+递归的方式,定义一个list存放节点中的val,在每次回溯时从list中弹出最后一个元素值,这样能够满足题目的要求,代码如下

404.左叶子之和

本题需要认真审题,要求的是做叶子节点只和不是二叉树的左节点,本题的难点在于遍历到叶子节点时无法判断是不是左叶子节点,只能在遍历到父节点的时候判断左孩子节点是不是左叶子节点。至于遍历顺序,因为需要先找到所有的左叶子节点,选择的是后序遍历,这题和235. 二叉搜索树的最近公共祖先思路相近,可以对比总结,代码如下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值