代码随想录算法【Day16】

Day16

513.找二叉树左下角的值

本题使用迭代法更简单,使用迭代法和递归法的区别是什么

递归法

目标就是找深度最大的叶子结点

无论前中后序遍历,都是左节点先被遍历到,所以一旦得到深度最大的节点,就是最后一行最靠左侧的节点

这里没有处理中的逻辑,因为前中后序都可以,只要强调左在右的前面

复制代码
class Solution {
public:
    int maxDepth = INT_MIN; //记录树的最大深度
    int result; //记录结点的值
    void traversal(TreeNode* root, int depth){
        if(root -> left == NULL && root -> right == NULL){ //判断是否为叶子结点
            if(depth > maxDepth){
                maxDepth = depth;
                result = root -> val;
            }
            return;
        }
​
        if(root -> left){ //如果存在左孩子
            depth ++;
            traversal(root -> left, depth);
            depth --; //回溯
        }
​
        if(root -> right){ //如果存在右孩子
            depth ++;
            traversal(root -> right, depth);
            depth --; //回溯
        }
        return;
    }
​
    int findBottomLeftValue(TreeNode* root) {
        traversal(root, 0);
        return result;
    }
};

一个节点只知道它的左右孩子节点而不知道它的父节点,而回溯实际上并不需要知道父节点,因为它利用了函数调用栈和局部变量的特性。

以下是具体的递归过程:

相关推荐
高山上有一只小老虎7 小时前
字符串字符匹配
java·算法
愚润求学7 小时前
【动态规划】专题完结,题单汇总
算法·leetcode·动态规划
MOONICK7 小时前
数据结构——哈希表
数据结构·哈希算法·散列表
林太白7 小时前
跟着TRAE SOLO学习两大搜索
前端·算法
ghie90908 小时前
图像去雾算法详解与MATLAB实现
开发语言·算法·matlab
云泽8088 小时前
从三路快排到内省排序:探索工业级排序算法的演进
算法·排序算法
weixin_468466858 小时前
遗传算法求解TSP旅行商问题python代码实战
python·算法·算法优化·遗传算法·旅行商问题·智能优化·np问题
·白小白9 小时前
力扣(LeetCode) ——43.字符串相乘(C++)
c++·leetcode
FMRbpm9 小时前
链表5--------删除
数据结构·c++·算法·链表·新手入门
程序员buddha9 小时前
C语言操作符详解
java·c语言·算法