js(JavaScript)数据结构之树(Tree)

2024-01-14 08:36

本文主要是介绍js(JavaScript)数据结构之树(Tree),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是数据结构?

下面是维基百科的解释:

数据结构是计算机存储、组织数据的方式。数据结构意味着接口或封装:一个数据结构可被视为两个函数之间的接口,或者是由数据类型联合组成的存储内容的访问方法封装。

我们每天的编码中都会用到数据结构,下面是常见的数据结构:

  • 数组(Array)
  • 栈(Stack)
  • 队列(Queue)
  • 链表(Linked List)
  • 散列表(Hash)
  • 字典
  • 树(Tree)
  • 图(Graph)
  • 堆(Heap)

树(Tree)

树(Tree)是一种常见的数据结构,由节点(Node)和边(Edge)组成。树的节点通过边连接,形成层次结构。树的一个节点可以有多个子节点,但只有一个父节点(除了根节点)。树的一个重要特点是没有环,即任意两个节点之间都有唯一的路径。

在树结构中,有一种特殊的树叫做二叉树。二叉树中,每个节点最多有两个子节点,一个是左节点,一个是右节点。这种设计的好处是我们可以通过限制每个节点的子节点个数为2,编写出高效的程序来进行插入、查找和删除数据操作。

二叉查找树(BST)是二叉树的一种,它有一个很聪明的性质:相对较小的值保存在左节点中,而较大的值保存在右节点中。这个性质使得在BST中进行查找操作非常高效,因为我们可以根据数值的大小迅速确定搜索方向。

举个例子,想象一个BST表示数字。根节点是一个中等大小的数字,比如50。如果我们要找的数字是30,由于30比50小,我们知道它应该在左节点。然后,如果我们要找的是60,因为60比50大,我们知道它应该在右节点。这样,我们可以在树中快速定位目标。

BST不仅适用于数值,还可以用于存储其他类型的数据,比如单词和字符串。这种树结构在计算机科学中被广泛应用,为数据的快速检索和操作提供了便利。

以下是一个使用 JavaScript 实现树的案例,演示了如何创建一个树、添加节点、遍历节点以及查找节点的功能:

HTML 代码:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>JavaScript实现树的案例</title>
</head><body><button onclick="addRoot()">添加根节点</button><button onclick="addChild()">添加子节点</button><button onclick="traversePreorder()">先序遍历树</button><button onclick="traverseInorder()">中序遍历树</button><button onclick="traversePostorder()">后序遍历树</button><br><br><label for="findInput">查找节点: </label><input type="text" id="findInput" placeholder="请输入"><button onclick="findNode()">查找节点</button><br><br><label for="result">结果: </label><span id="result"></span><script src="tree.js"></script>
</body></html>

JavaScript 代码:

// 定义树节点类
function TreeNode(value) {this.value = value;this.children = []; // 子节点数组
}// 定义树类
function Tree() {this.root = null; // 树的根节点// 添加根节点this.addRoot = function (value) {this.root = new TreeNode(value);};// 添加子节点this.addChild = function (parent, value) {var newNode = new TreeNode(value);parent.children.push(newNode);};// 先序遍历this.traversePreorder = function (node) {if (!node) return;console.log(node.value);for (var i = 0; i < node.children.length; i++) {this.traversePreorder(node.children[i]);}};// 中序遍历this.traverseInorder = function (node) {if (!node) return;for (var i = 0; i < node.children.length; i++) {this.traverseInorder(node.children[i]);}console.log(node.value);};// 后序遍历this.traversePostorder = function (node) {if (!node) return;for (var i = 0; i < node.children.length; i++) {this.traversePostorder(node.children[i]);}console.log(node.value);};// 查找节点this.findNode = function (node, value) {if (!node) return null;if (node.value === value) return node;for (var i = 0; i < node.children.length; i++) {var foundNode = this.findNode(node.children[i], value);if (foundNode) return foundNode;}return null;};
}// 创建一个树实例
var tree = new Tree();// 添加根节点
function addRoot() {var value = prompt("输入父值");tree.addRoot(value);console.log(tree.root);
}// 添加子节点
function addChild() {var parentValue = prompt("输入父值");var parent = tree.findNode(tree.root, parentValue);if (parent) {var value = prompt("输入子值");tree.addChild(parent, value);console.log(tree.root);} else {alert("找不到父节点");}
}// 先序遍历树
function traversePreorder() {if (tree.root) {tree.traversePreorder(tree.root);} else {console.log("树是空的");}
}// 中序遍历树
function traverseInorder() {if (tree.root) {tree.traverseInorder(tree.root);} else {console.log("树是空的");}
}// 后序遍历树
function traversePostorder() {if (tree.root) {tree.traversePostorder(tree.root);} else {console.log("树是空的");}
}// 查找节点
function findNode() {var value = document.getElementById("findInput").value;var foundNode = tree.findNode(tree.root, value);var resultSpan = document.getElementById("result");if (foundNode) {resultSpan.textContent = "找到节点: " + foundNode.value;} else {resultSpan.textContent = "未找到节点";}
}

这段代码是一个简单的实现树(Tree)数据结构的案例,通过 HTML 和 JavaScript 实现了创建树、添加节点、遍历节点以及查找节点的功能。下面是对代码的详细说明:

  1. HTML 结构:

    • 包含了几个按钮,分别用于添加根节点、添加子节点、先序遍历、中序遍历、后序遍历以及查找节点的操作。
    • 有一个输入框用于输入查找节点的值。
    • 一个用于显示查找结果的 <span> 元素。
  2. JavaScript 部分:

    • 树节点类 TreeNode 用于表示树中的节点,每个节点有一个值和一个子节点数组。

    • 树类 Tree 包含了以下功能:

      • addRoot(value): 添加根节点的方法。
      • addChild(parent, value): 添加子节点的方法。
      • traversePreorder(node): 先序遍历树的方法。
      • traverseInorder(node): 中序遍历树的方法。
      • traversePostorder(node): 后序遍历树的方法。
      • findNode(node, value): 查找节点的方法。
    • 树实例 tree 在代码最底部创建了一个树的实例。

    • 按钮点击事件处理函数:

      • addRoot(): 弹出对话框输入根节点的值,然后调用 addRoot 方法添加根节点。
      • addChild(): 弹出对话框输入父节点的值,查找该节点并弹出对话框输入子节点的值,然后调用 addChild 方法添加子节点。
      • traversePreorder(), traverseInorder(), traversePostorder(): 分别执行先序、中序、后序遍历。
      • findNode(): 从输入框获取查找值,调用 findNode 方法查找节点,并在页面上显示查找结果。
  3. 关键思路:

    • 树节点类和树类的设计使得可以轻松地表示树结构,并通过树类的方法实现了对树的基本操作。
    • 使用递归实现了树的遍历,包括先序、中序、后序遍历。
    • 查找节点的功能也是通过递归实现,遍历树的每个节点,当找到匹配值时返回节点。

总体来说,这段代码提供了一个简单的树结构操作界面,用户可以通过按钮执行不同的操作,包括添加节点、遍历节点和查找节点。

持续学习总结记录中,回顾一下上面的内容:
树(Tree)是一种常见的数据结构,由节点(Node)和边(Edge)组成。树的节点通过边连接,形成层次结构。树的一个节点可以有多个子节点,但只有一个父节点(除了根节点)。树的一个重要特点是没有环,即任意两个节点之间都有唯一的路径。

这篇关于js(JavaScript)数据结构之树(Tree)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/604547

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2