【前端面试】二叉树递归模板和题解

递归模板和步骤

递归题目的通用步骤

  1. 明确递归函数的功能:确定递归函数的输入参数和返回值,明确函数的功能。
  2. 基准情况(递归终止条件):设立一个或多个递归终止条件,确保递归能够结束。
  3. 递归步骤:将问题分解为更小的子问题,通过递归调用自身解决这些子问题。
  4. 合并结果:将子问题的解合并成原问题的解。

递归模板总结

1. 树的遍历(DFS)

前序遍历(根 -> 左 -> 右)

javascript 复制代码
function preorderTraversal(root) {
    let result = [];
    function traverse(node) {
        if (node !== null) {
            result.push(node.val);  // 访问根节点
            traverse(node.left);    // 递归遍历左子树
            traverse(node.right);   // 递归遍历右子树
        }
    }
    traverse(root);
    return result;
}

中序遍历(左 -> 根 -> 右)

javascript 复制代码
function inorderTraversal(root) {
    let result = [];
    function traverse(node) {
        if (node !== null) {
            traverse(node.left);    // 递归遍历左子树
            result.push(node.val);  // 访问根节点
            traverse(node.right);   // 递归遍历右子树
        }
    }
    traverse(root);
    return result;
}

后序遍历(左 -> 右 -> 根)

javascript 复制代码
function postorderTraversal(root) {
    let result = [];
    function traverse(node) {
        if (node !== null) {
            traverse(node.left);    // 递归遍历左子树
            traverse(node.right);   // 递归遍历右子树
            result.push(node.val);  // 访问根节点
        }
    }
    traverse(root);
    return result;
}
2. 二叉树的最大深度
javascript 复制代码
function maxDepth(root) {
    if (root === null) {
        return 0;
    }
    let leftDepth = maxDepth(root.left);
    let rightDepth = maxDepth(root.right);
    return Math.max(leftDepth, rightDepth) + 1;
}
3. 二叉树的最近公共祖先
javascript 复制代码
function lowestCommonAncestor(root, p, q) {
    if (root === null || root === p || root === q) {
        return root;
    }
    let left = lowestCommonAncestor(root.left, p, q);
    let right = lowestCommonAncestor(root.right, p, q);
    if (left !== null && right !== null) {
        return root;
    }
    return left !== null ? left : right;
}

递归题目的记忆技巧

  1. 确定递归函数的功能:明确函数的输入和输出,理解函数的目标。
  2. 设立基准情况:找到递归终止的条件,确保递归能够正确结束。
  3. 分解问题:将问题分解为更小的子问题,并通过递归调用解决。
  4. 合并结果:将子问题的解合并成原问题的解。
相关推荐
小小小小宇15 分钟前
软键盘常见问题(二)
前端
m0_6727033120 分钟前
上机练习第49天
数据结构·算法
样例过了就是过了25 分钟前
LeetCode热题100 N 皇后
数据结构·c++·算法·leetcode·dfs·深度优先遍历
霖大侠27 分钟前
CPAL: Cross-Prompting Adapter With LoRAs forRGB+X Semantic Segmentation
人工智能·深度学习·算法·机器学习·transformer
小小小小宇30 分钟前
软键盘常见问题
前端
小小小小宇1 小时前
富文本编辑器知识体系(三)
前端
小小小小宇1 小时前
富文本编辑器知识体系(二)
前端
品克缤1 小时前
Trading-Analysis:基于“规则+LLM”的行情分析终端(兼谈 Vibe Coding 实战感)
前端·后端·node.js·vue·express·ai编程·llama
近津薪荼1 小时前
优选算法——分治(2):快速选择
算法
隔壁小邓1 小时前
前端Vue项目打包部署实战教程
前端·javascript·vue.js