算法day16(补第15天)|用递归方法求解:513.找树左下角的值

@TOC

513.找树左下角的值

递归法(补day15)

难度较大,代码如下:

cpp 复制代码
class Solution {
public:
    int result;
    int maxdepth=INT_MIN;
    void traversal(TreeNode* root,int depth)
    {
        if(root->left==nullptr&&root->right==nullptr)
        {
            if(maxdepth<depth)
            {
                maxdepth=depth;
                result=root->val;
            }
            return;
        }
        if(root->left)
        {
            depth++;
            traversal(root->left,depth);
            depth--;
        }
        if(root->right)
        {
            depth++;
            traversal(root->right,depth);
            depth--;
        }
    }

    int findBottomLeftValue(TreeNode* root) {
        int depth=1;
        traversal(root,depth);
        return result; 
    }
};

总体思路(递归):

  • 参数 :在这题中,深度 是至关重要的参数,因为当遍历到叶子结点时,我们只有通过深度的大小来判断它是否是最后一层的结点。所以,深度肯定是在遍历中要变化的,所以把深度作为一个重要参数
  • **终止条件:**当以叶节点为终止条件时,基本上都伴有终止行为,这两者是相辅相成的。因为最后的结果也只能在叶节点出获取,所以也已叶节点为终止条件。这类题目一般会伴有回溯。
  • **单层递归逻辑:**由于没有什么对当前结点的操作,所以没有"中"了,直接上左右孩子。但是必须保证的是,左孩子一点过要在右孩子之前,目的:当左右孩子同时身处最后一层时,是左孩子先触碰到终止条件然后被赋值,然后右孩子再碰到终止条件,但是由于此时的depth==maxdepth,所以不能改变最后的result了,这就是此题最精妙之处。

一些代码细节

cpp 复制代码
class Solution {
public:
    int result;
    int maxdepth=INT_MIN;
  • 在力扣里面是可以设置一些全局变量的,这些全局变量在递归函数里面赋完值之后,回到主函数里面依然是递归函数里面所赋的值------即全局。
  • 还有一些贯穿整个递归过程的变量 也可以作为全局变量 ,如此处的maxdepth ,之前的vector result也是可以的。
相关推荐
GalaxyPokemon25 分钟前
LeetCode - 53. 最大子数组和
算法·leetcode·职场和发展
小猫咪怎么会有坏心思呢27 分钟前
华为OD机考 - 水仙花数 Ⅰ(2025B卷 100分)
数据结构·链表·华为od
weixin_4786897643 分钟前
C++ 对 C 的兼容性
java·c语言·c++
k要开心1 小时前
C++概念以及基础框架语法
开发语言·c++
hn小菜鸡1 小时前
LeetCode 1356.根据数字二进制下1的数目排序
数据结构·算法·leetcode
zhuiQiuMX1 小时前
分享今天做的力扣SQL题
sql·算法·leetcode
weixin_307779131 小时前
Linux下GCC和C++实现统计Clickhouse数据仓库指定表中各字段的空值、空字符串或零值比例
linux·运维·c++·数据仓库·clickhouse
music&movie2 小时前
算法工程师认知水平要求总结
人工智能·算法
秦少游在淮海2 小时前
C++ - string 的使用 #auto #范围for #访问及遍历操作 #容量操作 #修改操作 #其他操作 #非成员函数
开发语言·c++·stl·string·范围for·auto·string 的使用
const5442 小时前
cpp自学 day2(—>运算符)
开发语言·c++