110.平衡二叉树
平衡二叉树指的是一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。题目要求的是比较高度,必然是使用后续遍历,计算两个数之差(绝对值)使用函数Math.abs(int num1 - int num2),本题采用后续遍历的方法,递归遍历,代码如下
![](https://i-blog.csdnimg.cn/blog_migrate/4be887c0ce304dfb769d1dbf3ab59017.png)
257. 二叉树的所有路径
第一次遇到题目,看完题解后又实现了一遍,思路是使用前序遍历+递归的方式,定义一个list存放节点中的val,在每次回溯时从list中弹出最后一个元素值,这样能够满足题目的要求,代码如下
![](https://i-blog.csdnimg.cn/blog_migrate/fc13da0fe5b5d1c149ea5bcd89a02f56.png)
404.左叶子之和
本题需要认真审题,要求的是做叶子节点只和不是二叉树的左节点,本题的难点在于遍历到叶子节点时无法判断是不是左叶子节点,只能在遍历到父节点的时候判断左孩子节点是不是左叶子节点。至于遍历顺序,因为需要先找到所有的左叶子节点,选择的是后序遍历,这题和235. 二叉搜索树的最近公共祖先思路相近,可以对比总结,代码如下
![](https://i-blog.csdnimg.cn/blog_migrate/73e0704f573d0597d3bb750278c36c57.png)