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

本文实例讲述了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.jb51.net/code/HtmlJsRun测试上述代码,可得如下运行结果:

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

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

以上是 JavaScript数据结构与算法之二叉树插入节点、生成二叉树示例 的全部内容, 来源链接: utcz.com/z/328649.html

回到顶部