javascript实现二叉树的代码


Posted in Javascript onJune 08, 2017

前言:

javascript实现二叉树的代码

二叉树的特点(例图只是二叉树的一种情况,不要尝试用例图推理以下结论)

  1. 除了最下面一层,每个节点都是父节点,每个节点都有且最多有两个子节点;
  2. 除了嘴上面一层,每个节点是子节点,每个节点都会有一个父节点;
  3. 最上面一层的节点(即例图中的节点50)为根节点;

javascript实现二叉树的代码

最下面一层的节点称为叶子节点,他们没有子节点;

javascript实现二叉树的代码

左子节点的值 < 父节点的值 <= 右节点的值

1 节点的javascript实现

// 节点对象
function Node(data, left, right) {
  this.data = data; // 节点值
  this.left = left; // 当前节点的左子节点
  this.right = right; // 当前节点的右子节点
  this.show = show; // 辅助function
}

function show() {
  return this.data;
}

感受下上面实现节点的代码,感觉和链表有点相似不是吗,存着当前值,又存着下个节点(左、右子节点)的引用,下面是一张伪代码的草图:

javascript实现二叉树的代码

2 二叉树的实现

实现二叉树,当然就是要插入节点构成二叉树,先看看实现二叉树的js代码

function BST() {
  this.root = null;
  this.insert = insert;
}

function insert(data) {
  var n = new Node(data, null, null);
  if (this.root == null) {
   this.root = n;
  }
  else {
   var current = this.root;
   var parent;
   while (true) {
     parent = current;
     if (data < current.data) {
      current = current.left;
      if (current == null) {
        parent.left = n;
        break;
      }
     }
     else {
      current = current.right;
      if (current == null) {
        parent.right = n;
        break;
      }
     }
   }
  }
}

然后是看一下伪代码:

function BST() {
  this.root = null; // 根节点
  this.insert = insert;
}

function insert(data) {
  // 初始化一个节点,为什么要将左右子节点的引用初始化为空呢,因为可能是叶子节点,加入他有子节点,会在下面的代码添加
  var n = new Node(data, null, null);
  if (该二叉树是否为空,是空则根节点为空,因此可以用根节点判断二叉树是否为空) {
   // 将当前节点存为根节点
   this.root = n;
  }
  else {
   // 来到这里就表示,该二叉树不为空,这里关键的是两句代码:
   // 0.while (true);
   // 1.parent = current;
   // 2.current = current.left;/current = current.right;
   // 3.break;
   var current = this.root;
   var parent;
   while (true) {
     parent = current; // 获得父节点,第一次循环,那么父节点就是根节点
     if (data < current.data) { // 当前节点值小于父节点的值就是存左边,记得二叉树的特点吧,如果真是小于父节点,那么就说明该节点属于,该父节点的左子树。
      current = current.left;
      if (current == null) {
        parent.left = n;
        break;
      }

      // 其实上面这样写不好理解,可以等价于下面的代码:
      // start
      if(current.left == null){ // 若果左节点空,那么这个空的节点就是我们要插入的位置
        current.left = n;
        break;
      }else{
        // 不空则继续往下一层找空节点(插入的位置)
        current = current.left;
      }
      // end
     }
     else {
      // 右节点的逻辑代码个左节点的一样的
      current = current.right;
      if (current == null) {
        parent.right = n;
        break;
      }
     }
   }
  }
}

下面是一个更好理解的插入函数

function insert(data) {
  var n = new Node(data, null, null);
  if (this.root == null) {
   this.root = n;
  }
  else {
   var current = this.root;
   // start change
   while (true) {
     if (data < current.data) {
      if (current.left == null) {
        current.left = n;
        break;
      }else{
        current = current.left;
      }
     }else {
      if (current.right == null) {
        current.right = n;
        break;
      }else{
        current = current.right;
      }
     }
   }
  }
}

小结:

二叉树的实现的三个部件

Node对象

function Node(data, left, right) { ... }

BST对象

function BST() { ... }

插入节点函数

function insert(data) { ... }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery cdn使用介绍
May 08 Javascript
javascript操作excel生成报表示例
May 08 Javascript
js实现全国省份城市级联下拉菜单效果代码
Sep 07 Javascript
详解JavaScript正则表达式之RegExp对象
Dec 13 Javascript
Javascript基础_嵌入图像的简单实现
Jun 14 Javascript
前端构建工具之gulp的配置与搭建详解
Jun 12 Javascript
Vue.js学习笔记之常用模板语法详解
Jul 25 Javascript
Vue中正确使用jQuery的方法
Oct 30 jQuery
解决bootstrap-select 动态加载数据不显示的问题
Aug 10 Javascript
layer.confirm取消按钮绑定事件的方法
Aug 17 Javascript
解决vue 使用axios.all()方法发起多个请求控制台报错的问题
Nov 09 Javascript
Vue实现圆环进度条的示例
Feb 06 Vue.js
微信小程序搜索组件wxSearch实例详解
Jun 08 #Javascript
JS去掉字符串前后空格、阻止表单提交的实现代码
Jun 08 #Javascript
angular实现图片懒加载实例代码
Jun 08 #Javascript
微信小程序日历组件calendar详解及实例
Jun 08 #Javascript
php简单数据库操作类的封装
Jun 08 #Javascript
ReactJs设置css样式的方法
Jun 08 #Javascript
requirejs按需加载angularjs文件实例
Jun 08 #Javascript
You might like
PHP 编写的 25个游戏脚本
2009/05/11 PHP
PHP 各种排序算法实现代码
2009/08/20 PHP
php文件怎么打开 如何执行php文件
2011/12/21 PHP
PHP实现的英文名字全拼随机排号脚本
2014/07/04 PHP
PHP简单实现循环链表功能示例
2017/11/10 PHP
微信JS接口汇总及使用详解
2015/01/09 Javascript
JavaScript使用位运算符判断奇数和偶数的方法
2015/06/01 Javascript
javascript编写贪吃蛇游戏
2015/07/07 Javascript
使用jQuery mobile库检测url绝对地址和相对地址的方法
2015/12/04 Javascript
浏览器环境下JavaScript脚本加载与执行探析之defer与async特性
2016/01/14 Javascript
利用BootStrap的Carousel.js实现轮播图动画效果
2016/12/21 Javascript
ionic实现底部分享功能
2017/05/11 Javascript
AugularJS从入门到实践(必看篇)
2017/07/10 Javascript
bootstrap模态框嵌套、tabindex属性、去除阴影的示例代码
2017/10/17 Javascript
vue.js动画中的js钩子函数的实现
2018/07/06 Javascript
vue实现word,pdf文件的导出功能
2018/07/31 Javascript
Nodejs处理异常操作示例
2018/12/25 NodeJs
基于vue-cli3创建libs库的实现方法
2019/12/04 Javascript
python实现数值积分的Simpson方法实例分析
2015/06/05 Python
Python 从相对路径下import的方法
2018/12/04 Python
python实现共轭梯度法
2019/07/03 Python
如何不用安装python就能在.NET里调用Python库
2019/07/12 Python
python上传时包含boundary时的解决方法
2020/04/08 Python
Python基于requests实现模拟上传文件
2020/04/21 Python
学习python需要有编程基础吗
2020/06/02 Python
Keras中的两种模型:Sequential和Model用法
2020/06/27 Python
html5超简单的localStorage实现记住密码的功能实现
2017/09/07 HTML / CSS
Backcountry旗下的户外商品闪购网站:steep&cheap
2016/09/22 全球购物
通信专业个人自我鉴定
2013/10/21 职场文书
生产部厂长助理职位说明书
2014/03/03 职场文书
战略合作意向书范本
2014/04/01 职场文书
机械机修工岗位职责
2014/08/03 职场文书
房屋维修申请报告
2015/05/18 职场文书
文化大革命观后感
2015/06/17 职场文书
基于go interface{}==nil 的几种坑及原理分析
2021/04/24 Golang
低版本Druid连接池+MySQL驱动8.0导致线程阻塞、性能受限
2021/07/01 MySQL