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

递归模板和步骤

递归题目的通用步骤

  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. 合并结果:将子问题的解合并成原问题的解。
相关推荐
Wect几秒前
HTML5 原生拖拽 API 基础原理与核心机制
前端·面试·html
Ruihong2 分钟前
Vue 转 React:揭秘样式语言是如何被 VuReact 编译的?
vue.js·react.js·面试
用户游民2 分钟前
Android 的 FragmentTransaction 中,hide() 和 add() 方法的执行顺序
前端
前端技术2 分钟前
华为余承东:鸿蒙终端设备数突破5500万
java·前端·javascript·人工智能·python·华为·harmonyos
深海鱼在掘金2 分钟前
Next.js从入门到实战保姆级教程(第五章):数据获取与缓存策略
前端·typescript·next.js
深海鱼在掘金4 分钟前
Next.js从入门到实战保姆级教程(第四章):路由系统详解
前端·typescript·next.js
leafyyuki6 分钟前
从零到一落地「智能助手」:一次基于 OpenSpec 的流式对话前端实践
前端·vue.js·人工智能
qeen877 分钟前
【算法笔记】差分与经典例题解析
c语言·c++·笔记·学习·算法·差分
踩着两条虫7 分钟前
VTJ:架构设计模式
前端·架构·ai编程
孙凯亮8 分钟前
Three.js VR 模拟器(Immersive Web Emulator)踩坑全记录:从报错到可用,避坑指南一次性奉上
前端·three.js