首页 > 编程 > JavaScript > 正文

JavaScript数据结构与算法之二叉树插入节点、生成二叉树示例

2019-11-19 12:05:14
字体:
来源:转载
供稿:网友

本文实例讲述了JavaScript数据结构与算法之二叉树插入节点、生成二叉树。分享给大家供大家参考,具体如下:

javascript数据结构与算法-- 插入节点、生成二叉树

二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中

/**二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中*** *//*用来生成一个节点*/function Node(data, left, right) {  this.data = data;//节点存储的数据  this.left = left;  this.right = right;  this.show = show;}function show() {  return this.data;}/*用来生成一个二叉树*/function BST() {  this.root = null;  this.insert = insert;}/*将数据插入二叉树  (1)设根节点为当前节点。  (2)如果待插入节点保存的数据小于当前节点,则设新的当前节点为原节点的左节点;反  之,执行第4步。  (3)如果当前节点的左节点为null,就将新的节点插入这个位置,退出循环;反之,继续  执行下一次循环。  (4)设新的当前节点为原节点的右节点。  (5)如果当前节点的右节点为null,就将新的节点插入这个位置,退出循环;反之,继续  执行下一次循环。* */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) {//如果当前节点的左节点为null,就将新的节点插入这个位置,退出循环;反之,继续执行下一次while循环。          parent.left = n;          break;        }      }      else {        current = current.right;//待插入节点保存的数据小于当前节点,则设新的当前节点为原节点的左节点        if (current == null) {          parent.right = n;          break;        }      }    }  }}var nums = new BST();nums.insert(23);nums.insert(45);nums.insert(16);nums.insert(37);nums.insert(3);nums.insert(99);nums.insert(22);console.log(nums);

使用在线HTML/CSS/JavaScript代码运行工具http://tools.VeVB.COm/code/HtmlJsRun测试上述代码,可得如下运行结果:

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数据结构与算法技巧总结》、《JavaScript数学运算用法总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结

希望本文所述对大家JavaScript程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表