javascript数据结构之二叉搜索树实现方法


Posted in Javascript onNovember 25, 2015

本文实例讲述了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程序设计有所帮助。

Javascript 相关文章推荐
一个很酷的拖动层的js类,兼容IE及Firefox
Jun 23 Javascript
javascript 文件的同步加载与异步加载实现原理
Dec 13 Javascript
Jquery创建一个层当鼠标移动到层上面不消失效果
Dec 12 Javascript
javascript实用方法总结
Feb 06 Javascript
jQuery实现表格元素动态创建功能
Jan 09 Javascript
JavaScript中的return布尔值的用法和原理解析
Aug 14 Javascript
node.js学习之事件模块Events的使用示例
Sep 28 Javascript
vue Element-ui input 远程搜索与修改建议显示模版的示例代码
Oct 19 Javascript
说说node中的可读流和可写流的区别
Jun 01 Javascript
JS数组方法reduce的用法实例分析
Mar 03 Javascript
vue在响应头response中获取自定义headers操作
Jul 24 Javascript
vue内置组件keep-alive事件动态缓存实例
Oct 30 Javascript
javascript常用经典算法实例详解
Nov 25 #Javascript
javascript实现很浪漫的气泡冒出特效
Sep 05 #Javascript
jQuery插件jquery-barcode实现条码打印的方法
Nov 25 #Javascript
JavaScript编写简单的计算器
Nov 25 #Javascript
HTML5 Shiv完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法
Nov 25 #Javascript
jQuery插件formValidator自定义函数扩展功能实例详解
Nov 25 #Javascript
jQuery实现鼠标双击Table单元格变成文本框及输入内容后更新到数据库的方法
Nov 25 #Javascript
You might like
php快递单号查询接口使用示例
2014/05/05 PHP
PHP安装threads多线程扩展基础教程
2015/11/17 PHP
PHP Ajax JavaScript Json获取天气信息实现代码
2016/08/17 PHP
php实现压缩合并js的方法【附demo源码下载】
2016/09/22 PHP
php函数式编程简单示例
2019/08/08 PHP
WordPress JQuery处理沙发头像
2009/06/22 Javascript
关于Mozilla浏览器不支持innerText的解决办法
2011/01/01 Javascript
js中根据字数截取字符串,不能截断url
2012/01/12 Javascript
一个JQuery操作Table的代码分享
2012/03/30 Javascript
基于jQuery选择器的整理集合
2013/04/26 Javascript
浅析node.js中close事件
2014/11/26 Javascript
详解JS函数重载
2014/12/04 Javascript
js动态修改表格行colspan列跨度的方法
2015/03/30 Javascript
详解JavaScript ES6中的模板字符串
2015/07/28 Javascript
Javascript将双字节字符转换成单字节字符并计算长度
2016/06/22 Javascript
微信小程序时间选择插件使用详解
2018/12/28 Javascript
vue.js基于v-for实现批量渲染 Json数组对象列表数据示例
2019/08/03 Javascript
vue+vant使用图片预览功能ImagePreview的问题解决
2020/04/10 Javascript
使用Python操作Elasticsearch数据索引的教程
2015/04/08 Python
在Python中操作列表之List.append()方法的使用
2015/05/20 Python
分析python切片原理和方法
2017/12/19 Python
python爬取足球直播吧五大联赛积分榜
2018/06/13 Python
使用python对文件中的单词进行提取的方法示例
2018/12/21 Python
python实现浪漫的烟花秀
2019/01/30 Python
python输入错误后删除的方法
2019/10/12 Python
Python基于codecs模块实现文件读写案例解析
2020/05/11 Python
对Python 字典元素进行删除的方法
2020/07/31 Python
努比亚手机官网:nubia
2016/10/06 全球购物
企业治理工作自我评价
2013/09/26 职场文书
扩大国家免疫规划实施方案
2014/03/21 职场文书
勿忘国耻9.18演讲稿(经典篇)
2014/09/14 职场文书
工商行政处罚决定书
2015/06/24 职场文书
感恩的心主题班会
2015/08/12 职场文书
大学生团支书竞选稿
2015/11/21 职场文书
纯 CSS 自定义多行省略的问题(从原理到实现)
2021/11/11 HTML / CSS
yolov5返回坐标的方法实例
2022/03/17 Python