题目

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

递归解

左下角要满足两个条件:
1、深度最大的叶子结点
2、最左结点:使用前序遍历,优先左边搜索。
1、确定递归函数的参数和返回值
参数:树的根结点,maxlen记录最大深度,maxleftval记录最大深度最左结点的数值。

int maxlen = 0;     //全局变量,记录最大深度
int maxleftval;     //全局变量 最大深度最左节点的数值
void traversal(TreeNode* root,int leftlen);

2、确定终止条件
遇到叶子结点,统计一下最大深度

if(root->left == NULL && root->right == NULL)
{if(leftlen > maxlen)        //如果是同一深度则不会进行更新数值{maxlen=leftlen;     //更新最大深度maxleftval = root->val;     //最大深度最左边的数值}return ;
}

3、确定单层逻辑
和之前的思路一样,在找最大深度的时候,递归过程中依然要使用回溯

//中,不需要操作
if(root->left)
{leftlen++;   //深度+1traversal(root->left,leflen);leftlen--;   //回溯,深度-1
}
if(root->right)
{leftlen++;   //深度+1traversal(root->right,leflen);leftlen--;  //回溯,深度-1
}
return ;

完整代码

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {public:int maxlen = -1;        //全局变量,记录最大深度int maxleftval;     //全局变量 最大深度最左节点的数值void traversal(TreeNode* root,int leftlen){if(root->left == NULL && root->right == NULL){if(leftlen > maxlen)        //如果是同一深度则不会进行更新数值{maxlen=leftlen;     //更新最大深度maxleftval = root->val;     //最大深度最左边的数值}return ;}//中,不需要操作if(root->left){leftlen++;    //深度+1traversal(root->left,leftlen);leftlen--;  //回溯,深度-1}if(root->right){leftlen++;    //深度+1traversal(root->right,leftlen);leftlen--; //回溯,深度-1}return ;}int findBottomLeftValue(TreeNode* root) {traversal(root,0);return maxleftval;}
};

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

层序遍历解

层序遍历,将每层第一个元素赋值给一个变量result。遍历所有层,最后的result就是结果

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {public:int findBottomLeftValue(TreeNode* root) {int result=0;queue<TreeNode*> que;if(root!=NULL) que.push(root);while(!que.empty()){//该层结点元素个数 = 该层队列元素int size = que.size();//这里要使用固定大小的size,不能使用que.size(),因为在处理中que.size是不断变化的//将这层元素送入队列中并依次从队首向队尾将元素出队列,每个元素出队列的同时又将其不为空的子结点送入队列for(int i =0;i<size;i++){if(i==0) result = que.front()->val;TreeNode* node = que.front();//将队首元素送入该层结果que.pop();//将左右孩子结点入队列,作为下一层的元素if(node->left) que.push(node->left);if(node->right) que.push(node->right);}}return result;}
};

LeetCode 513. 找树左下角的值 思考分析相关推荐

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

最新文章

  1. python opencv 如何检测模糊图像?自动判断模糊程度 cv2.Laplacian().var()
  2. SAP Spartacus 如何借助env-cmd 实现 B2B 和 B2C 功能启动的无缝切换
  3. c语言程序设计的一般错误的是,《C语言程序设计》第十章 程序常见错误分析.pdf...
  4. MySQL的索引创建、删除
  5. linux 开机默认启动windows系统时间,Windows和Linux双系统批改默认启动项、超时时间...
  6. java必学的技术,终于有人把Java程序员必学知识点整理出来了,令人有如醍醐灌顶...
  7. Oracle轻量级客户端下载,Oracle轻量级客户端使用,Oracle轻量级客户端配置,本地同时安装服务器端和客户端,并实现plsql developer连接
  8. 傅里叶级数、一维傅里叶变换到二维傅里叶变换数理推导
  9. 如何通过学习实现人生的逆袭!
  10. 线性代数在计算机视觉的应用,线性代数在数据科学中的十大强大应用(二)
  11. MATLAB求解复系数特征方程的实数根的方法
  12. 私域增长 | 私域会员:9大连锁行业15个案例集锦
  13. AI学习之路(19)TensorFlow里的矩阵乘法
  14. 用Processing制作小游戏1
  15. Xtensa DSP结构学习
  16. lol网通服务器位置,LOL转区系统地址在哪里 国服转区方法介绍
  17. 理财收益天基实业选择投资理财快速改变人生轨迹
  18. UE4开发PSVR游戏流程
  19. OpenCV入门学习笔记之Harris角点检测与SIFT特征匹配算法
  20. Cross-validation and KNN

热门文章

  1. 前端常见浏览器兼容性问题及解决办法
  2. Myesclipe+SSH+jsp+mysql+tomcate实现一个简单的CRM客户关系管理系统
  3. css 汉字注音,日本语片假名
  4. BZOJ5093图的价值(斯特林数)
  5. linux ubuntu 关于vim得一些基本命令
  6. python函数-函数进阶
  7. Python服务器开发三:Socket
  8. 【J2EE设计模式】模型-视图-控制器模式(MVC模式)
  9. java单例模式理解_快速理解Java中的五种单例模式
  10. java gson fromjson,Gson的fromJson()方法