本文实例讲述了javascript二叉搜索树实现方法。分享给大家供大家参考,具体如下:
二叉搜索树:顾名思义,树上每个节点最多只有二根分叉;而且左分叉节点的值 。
特点:插入节点、找最大/最小节点、节点值排序 非常方便
二叉搜索树-javascript实现
<script type="text/javascript"> // <![CDATA[ //打印输出 function println(msg) { document.write(msg + " "); } //节点类 var Node = function (v) { this.data = v; //节点值 this.left = null; //左节点 this.right = null; //右节点 } //二叉搜索树类 var BinarySearchTree = function () { this.root = null; //初始化时,根节点为空 //插入节点 //参数:v 为节点的值 this.insert = function (v) { var newNode = new Node(v); if (this.root == null) { //树为空时,新节点,直接成为根节点 this.root = newNode; return; } var currentNode = this.root; //工作“指针”节点(从根开始向下找) var parentNode = null; while (true) { parentNode = currentNode; if (v < currentNode.data) { //当前节点的值 > 目标节点的值 //应该向左插,工作节点移到左节点 currentNode = currentNode.left; if (currentNode == null) { //没有左节点,则新节点,直接成为左节点 parentNode.left = newNode; return; //退出循环 } } else { //否则向右插,工作节点移到右节点 currentNode = currentNode.right; if (currentNode == null) { parentNode.right = newNode; return; } } } } //查找最小节点 this.min = function () { var p = this.root; //工作节点 while (p != null && p.left != null) { p = p.left; } return p; } //查找最大节点 this.max = function () { var p = this.root; //工作节点 while (p != null && p.right != null) { p = p.right; } return p; } //中序遍历 this.inOrder = function (rootNode) { if (rootNode != null) { this.inOrder(rootNode.left); //先左节点 println(rootNode.data); //再根节点 this.inOrder(rootNode.right); //再右节点 } } //先序遍历 this.preOrder = function (rootNode) { if (rootNode != null) { println(rootNode.data); //先根 this.preOrder(rootNode.left); //再左节点 this.preOrder(rootNode.right); //再右节点 } } //后序遍历 this.postOrder = function (rootNode) { if (rootNode != null) { this.postOrder(rootNode.left); //先左节点 this.postOrder(rootNode.right); //再右节点 println(rootNode.data); //再根节点 } } } //以下是测试 var bTree = new BinarySearchTree(); //《沙特.算法设计技巧与分析》书上图3.9 左侧的树 bTree.insert(6); bTree.insert(3); bTree.insert(8); bTree.insert(1); bTree.insert(4); bTree.insert(9); println('中序遍历:') bTree.inOrder(bTree.root); println("<br/>"); println("先序遍历:"); bTree.preOrder(bTree.root); println("<br/>"); println("后序遍历:"); bTree.postOrder(bTree.root); println("<br/>"); var minNode = bTree.min(); println("最小节点:" + (minNode == null ? "不存在" : minNode.data)); println("<br/>"); var maxNode = bTree.max(); println("最大节点:" + (maxNode == null ? "不存在" : maxNode.data)); // ]]> </script> <!--中序遍历: 1 3 4 6 8 9 <br> 先序遍历: 6 3 1 4 8 9 <br> 后序遍历: 1 4 3 9 8 6 <br> 最小节点:1 <br> 最大节点:9-->
输出结果:
中序遍历: 1 3 4 6 8 9 先序遍历: 6 3 1 4 8 9 后序遍历: 1 4 3 9 8 6 最小节点:1 最大节点:9
希望本文所述对大家JavaScript程序设计有所帮助。

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

禅工作室 13.0.1
功能强大的PHP集成开发环境

Atom编辑器mac版下载
最流行的的开源编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver Mac版
视觉化网页开发工具