数据结构:二叉树遍历

在 JavaScript 中实现二叉树的遍历,可以使用递归或迭代的方式。以下是三种常见的遍历方式:前序遍历 (Pre-order)、中序遍历 (In-order)和后序遍历(Post-order)。

定义二叉树节点类

js 复制代码
class TreeNode {
    constructor(val) {
        this.val = val;
        this.left = null;
        this.right = null;
    }
}

前序遍历(Pre-order Traversal)

前序遍历的顺序是:根节点 -> 左子树 -> 右子树。

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

中序遍历(In-order Traversal)

中序遍历的顺序是:左子树 -> 根节点 -> 右子树。

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

后序遍历(Post-order Traversal)

后序遍历的顺序是:左子树 -> 右子树 -> 根节点。

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

假设有这样一颗树

js 复制代码
	1
   / \
  2   3
 / \
4   5

我们可以创建这棵树并进行遍历:

js 复制代码
const root = new TreeNode(1);
root.left = new TreeNode(2);
root.right = new TreeNode(3);
root.left.left = new TreeNode(4);
root.left.right = new TreeNode(5);

console.log(preOrderTraversal(root)); // 输出: [1, 2, 4, 5, 3]
console.log(inOrderTraversal(root)); // 输出: [4, 2, 5, 1, 3]
console.log(postOrderTraversal(root)); // 输出: [4, 5, 2, 3, 1]

本内容由AI搜索,仅供学习参考

相关推荐
txinyu的博客23 分钟前
map和unordered_map的性能对比
开发语言·数据结构·c++·算法·哈希算法·散列表
im_AMBER41 分钟前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
予枫的编程笔记41 分钟前
【Java集合】深入浅出 Java HashMap:从链表到红黑树的“进化”之路
java·开发语言·数据结构·人工智能·链表·哈希算法
X在敲AI代码1 小时前
leetcodeD3
数据结构·算法
余瑜鱼鱼鱼1 小时前
Java数据结构:从入门到精通(十一)
数据结构
荒诞硬汉2 小时前
数组常见算法
java·数据结构·算法
2301_800256112 小时前
B+树:数据库的基石 R树:空间数据的索引专家 四叉树:空间划分的网格大师
数据结构·数据库·b树·机器学习·postgresql·r-tree
码农幻想梦2 小时前
第九章 高级数据结构
数据结构
AlenTech2 小时前
206. 反转链表 - 力扣(LeetCode)
数据结构·leetcode·链表
大厂技术总监下海3 小时前
用户行为分析怎么做?ClickHouse + 嵌套数据结构,轻松处理复杂事件
大数据·数据结构·数据库