本文 https://github.com/youngyangyang04/leetcode-master 已经收录,里面还有leetcode刷题攻略、各个类型经典题目刷题顺序、思维导图,可以fork到自己仓库,有空看一看一定会有所收获,如果对你有帮助也给一个star支持一下吧!

513.找树左下角的值

给定一个二叉树,在树的最后一行找到最左边的值。

示例 1:

示例 2:

思路

本地要找出树的最后一行找到最左边的值。此时大家应该想起用层序遍历是非常简单的了,反而用递归的话会比较难一点。

我们依然还是先介绍递归法。

递归

咋眼一看,这道题目用递归的话就就一直向左遍历,最后一个就是答案呗?

没有这么简单,一直向左遍历到最后一个,它未必是最后一行啊。

我们来分析一下题目:在树的最后一行找到最左边的值

首先要是最后一行,然后是最左边的值。

如果使用递归法,如何判断是最后一行呢,其实就是深度最大的叶子节点一定是最后一行。

如果对二叉树深度和高度还有点疑惑的话,请看:二叉树:我平衡么?。

所以要找深度最大的叶子节点。

那么如果找最左边的呢?可以使用前序遍历,这样才先优先左边搜索,然后记录深度最大的叶子节点,此时就是树的最后一行最左边的值。

递归三部曲:

  1. 确定递归函数的参数和返回值

参数必须有要遍历的树的根节点,还有就是一个int型的变量用来记录最长深度。 这里就不需要返回值了,所以递归函数的返回类型为void。

本题还需要类里的两个全局变量,maxLen用来记录最大深度,maxleftValue记录最大深度最左节点的数值。

代码如下:

int maxLen = INT_MIN;   // 全局变量 记录最大深度
int maxleftValue;       // 全局变量 最大深度最左节点的数值
void traversal(TreeNode* root, int leftLen)

有的同学可能疑惑,为啥不能递归函数的返回值返回最长深度呢?

其实很多同学都对递归函数什么时候要有返回值,什么时候不能有返回值很迷茫。

如果需要遍历整颗树,递归函数就不能有返回值。如果需要遍历某一条固定路线,递归函数就一定要有返回值!

初学者可能对这个结论不太理解,别急,后面我会安排一道题目专门讲递归函数的返回值问题。这里大家暂时先了解一下。

本题我们是要遍历整个树找到最深的叶子节点,需要遍历整颗树,所以递归函数没有返回值。

  1. 确定终止条件

当遇到叶子节点的时候,就需要统计一下最大的深度了,所以需要遇到叶子节点来更新最大深度。

代码如下:

if (root->left == NULL && root->right == NULL) {if (leftLen > maxLen) {maxLen = leftLen;           // 更新最大深度maxleftValue = root->val;   // 最大深度最左面的数值 }return;
}
  1. 确定单层递归的逻辑

在找最大深度的时候,递归的过程中依然要使用回溯,代码如下:

                    // 中
if (root->left) {   // 左leftLen++; // 深度加一     traversal(root->left, leftLen);leftLen--; // 回溯,深度减一
}
if (root->right) { // 右leftLen++; // 深度加一traversal(root->right, leftLen);leftLen--; // 回溯,深度减一
}
return;

完整代码如下:

class Solution {
public:int maxLen = INT_MIN;int maxleftValue;void traversal(TreeNode* root, int leftLen) {if (root->left == NULL && root->right == NULL) {if (leftLen > maxLen) {maxLen = leftLen;maxleftValue = root->val;}return;}if (root->left) {leftLen++;traversal(root->left, leftLen);leftLen--; // 回溯}if (root->right) {leftLen++;traversal(root->right, leftLen);leftLen--; // 回溯 }return;}int findBottomLeftValue(TreeNode* root) {traversal(root, 0);return maxleftValue;}
};

当然回溯的地方可以精简,精简代码如下:

class Solution {
public:int maxLen = INT_MIN;int maxleftValue;void traversal(TreeNode* root, int leftLen) {if (root->left == NULL && root->right == NULL) {if (leftLen > maxLen) {maxLen = leftLen;maxleftValue = root->val;}return;}if (root->left) {traversal(root->left, leftLen + 1); // 隐藏着回溯}if (root->right) {traversal(root->right, leftLen + 1); // 隐藏着回溯}return;}int findBottomLeftValue(TreeNode* root) {traversal(root, 0);return maxleftValue;}
};

如果对回溯部分精简的代码 不理解的话,可以看这篇二叉树:找我的所有路径?和二叉树:以为使用了递归,其实还隐藏着回溯 。这两篇文章详细分析了回溯隐藏在了哪里。

迭代法

本题使用层序遍历再合适不过了,比递归要好理解的多!

只需要记录最后一行第一个节点的数值就可以了。

如果对层序遍历不了解,看这篇二叉树:层序遍历登场!,这篇里也给出了层序遍历的模板,稍作修改就一过刷了这道题了。

代码如下:

class Solution {
public:int findBottomLeftValue(TreeNode* root) {queue<TreeNode*> que;if (root != NULL) que.push(root);int result = 0;while (!que.empty()) {int size = que.size();for (int i = 0; i < size; i++) {TreeNode* node = que.front();que.pop();if (i == 0) result = node->val; // 记录最后一行第一个元素if (node->left) que.push(node->left);if (node->right) que.push(node->right);}}return result;}
};

总结

本题涉及如下几点:

  • 递归求深度的写法,我们在二叉树:我平衡么?中详细的分析了深度应该怎么求,高度应该怎么求。
  • 递归中其实隐藏了回溯,在二叉树:以为使用了递归,其实还隐藏着回溯中讲解了究竟哪里使用了回溯,哪里隐藏了回溯。
  • 层次遍历,在二叉树:层序遍历登场!深度讲解了二叉树层次遍历。

所以本题涉及到的点,我们之前都讲解过,这些知识点需要同学们灵活运用,这样就举一反三了。

我是程序员Carl,利用工作之余重刷leetcode,更多精彩算法文章尽在:代码随想录,关注后,回复「Java」「C++」「python」「简历模板」等等,有我整理多年的学习资料,可以加我微信,备注「简单自我介绍」+「组队刷题」,拉你进入刷题群(无任何广告,纯个人分享),每天一道经典题目分析,我选的每一道题目都不是孤立的,而是由浅入深一脉相承的,如果跟住节奏每篇连续着看,定会融会贯通。

以下资料希望对你有帮助:

  • 学习资料以及我的开源项目
  • 我的B站视频:算法和编程语言的讲解
  • leetcode刷题攻略
  • 程序员应该如何写简历(附简历模板)
  • 一线互联网公司技术面试的流程以及注意事项
  • C++面试&C++学习指南知识点整理

如果感觉题解对你有帮助,不要吝啬给一个

「leetcode」513.找树左下角的值(详解)相关推荐

  1. Java实现 LeetCode 513 找树左下角的值

    513. 找树左下角的值 给定一个二叉树,在树的最后一行找到最左边的值. 示例 1: 输入: 2/ \1 3 输出: 1 示例 2: 输入: 1/ \2 3/ / \ 4 5 6/7 输出: 7 注意 ...

  2. Suzy找到实习了吗Day 18 | 二叉树进行中:513 找树左下角的值,112 路径总和 ,106.从中序与后序遍历序列构造二叉树

    513 找树左下角的值 solution # Definition for a binary tree node. # class TreeNode: # def __init__(self, val ...

  3. LeetCode 513. 找树左下角的值 思考分析

    题目 给定一个二叉树,在树的最后一行找到最左边的值. 递归解 左下角要满足两个条件: 1.深度最大的叶子结点 2.最左结点:使用前序遍历,优先左边搜索. 1.确定递归函数的参数和返回值 参数:树的根结 ...

  4. LeetCode 513. 找树左下角的值(按层遍历 queue)

    1. 题目 给定一个二叉树,在树的最后一行找到最左边的值. 2. 解题 利用队列按层次遍历 顺序,根右左,要求最左边的一个,所以根右左,最后一个队列元素就是答案 class Solution {pub ...

  5. leetcode —— 513. 找树左下角的值

    给定一个二叉树,在树的最后一行找到最左边的值. 示例 1: 示例 2: 解题思路:使用广度优先遍历,因为题目要求寻找的是最底层的最左边的节点.因此我们维护一个变量--节点所在的树的高度,设根节点的高度 ...

  6. LeetCode 513. 找树左下角的值(递归)

    题目描述 给定一个二叉树,在树的最后一行找到最左边的值. 思路 详见链接 代码 class Solution:def findBottomLeftValue(self,root:TreeNode) - ...

  7. 2022-5-5 Leetcode 513.找树左下角的值

    层序遍历 -- 每层的第一个节点即可. /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode * ...

  8. 力扣513. 找树左下角的值(JavaScript)

    //层序遍历 var findBottomLeftValue = function(root) { let resultlet q=[root]while(q.length){//取出一个节点,需要加 ...

  9. 代码随想录第18天|找树左下角的值,路径总和,从中序和后序遍历序列构造二叉树

    LeetCode513.找树左下角的值 题目链接:513. 找树左下角的值 - 力扣(LeetCode) 思路: 迭代法(只需要记录最后一行第一个节点的数值就可以了.): /*** Definitio ...

  10. 找树左下角的值+路径总和+从前序和中序遍历序列构造二叉树(day18*)

    这篇可以主要关注一下如何确定递归时是否需要返回值. LC513. 找树左下角的值 给定一个二叉树的根节点,请找出该二叉树的 最底层最左边 节点的值. 思路1 层序遍历 class Solution:d ...

最新文章

  1. 液体测量技术:从水到血液
  2. 十折交叉验证10-fold cross validation, 数据集划分 训练集 验证集 测试集
  3. 从通信到AI FreeSWITCH与WebRTC
  4. scrapy 搜索关键字_Scrapy 新浪微博搜索爬虫
  5. java 方法 示例_Java集合syncedSortedSet()方法与示例
  6. 阿里云服务器被[kthreaddi]挖矿病毒攻击
  7. 苹果cms快鸭影视海螺精品模板
  8. open函数返回-1_记录学习python的第3天-递归函数/文件操作
  9. 列表页的动态条件搜索
  10. win10设置禁止系统更新
  11. STM8学习笔记---NTC热敏电阻的使用
  12. Grafana 系统可视化监控
  13. EXPLAIN PLAN用法小议
  14. linux查看网卡吞吐量和网卡流量用自带命令,iptraf查看。
  15. 银行的起源---》阮一峰,
  16. InfoPath基础应用教程-1 设计一个简单的表单模板
  17. 图像处理中的几种预处理方式
  18. 《人类简史-从动物到上帝》读后感
  19. 排列奇偶性与排序的关系
  20. vue-loader

热门文章

  1. Star UML指导手册
  2. 分布的距离(Distance of Distributions)
  3. ZED2+ORB_SLAM3
  4. ubuntu增加磁盘容量
  5. 用netbeans开发Swing程序,添加自定义控件
  6. 正六边形网格化(Hexagonal Grids)原理与实现
  7. 添加常见 URL Scheme 列表,方便快速查询⓶QA:URL Scheme适配好为何仍然报错
  8. BZOJ【1606】购买干草
  9. 【面试题7】用两个栈实现队列
  10. UILabel显示html文本