JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹插入節(jié)點、生成二叉樹示例
本文實例講述了JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹插入節(jié)點、生成二叉樹。分享給大家供大家參考,具體如下:
javascript數(shù)據(jù)結(jié)構(gòu)與算法-- 插入節(jié)點、生成二叉樹
二叉樹中,相對較小的值保存在左節(jié)點上,較大的值保存在右節(jié)點中

/*
*二叉樹中,相對較小的值保存在左節(jié)點上,較大的值保存在右節(jié)點中
*
*
* */
/*用來生成一個節(jié)點*/
function Node(data, left, right) {
this.data = data;//節(jié)點存儲的數(shù)據(jù)
this.left = left;
this.right = right;
this.show = show;
}
function show() {
return this.data;
}
/*用來生成一個二叉樹*/
function BST() {
this.root = null;
this.insert = insert;
}
/*將數(shù)據(jù)插入二叉樹
(1)設(shè)根節(jié)點為當前節(jié)點。
(2)如果待插入節(jié)點保存的數(shù)據(jù)小于當前節(jié)點,則設(shè)新的當前節(jié)點為原節(jié)點的左節(jié)點;反
之,執(zhí)行第4步。
(3)如果當前節(jié)點的左節(jié)點為null,就將新的節(jié)點插入這個位置,退出循環(huán);反之,繼續(xù)
執(zhí)行下一次循環(huán)。
(4)設(shè)新的當前節(jié)點為原節(jié)點的右節(jié)點。
(5)如果當前節(jié)點的右節(jié)點為null,就將新的節(jié)點插入這個位置,退出循環(huán);反之,繼續(xù)
執(zhí)行下一次循環(huán)。
* */
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;//待插入節(jié)點保存的數(shù)據(jù)小于當前節(jié)點,則設(shè)新的當前節(jié)點為原節(jié)點的左節(jié)點
if (current == null) {//如果當前節(jié)點的左節(jié)點為null,就將新的節(jié)點插入這個位置,退出循環(huán);反之,繼續(xù)執(zhí)行下一次while循環(huán)。
parent.left = n;
break;
}
}
else {
current = current.right;//待插入節(jié)點保存的數(shù)據(jù)小于當前節(jié)點,則設(shè)新的當前節(jié)點為原節(jié)點的左節(jié)點
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測試上述代碼,可得如下運行結(jié)果:

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)學(xué)運算用法總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
- JavaScript數(shù)據(jù)結(jié)構(gòu)和算法之二叉樹詳解
- JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的刪除算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的查找算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的遍歷算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)之二叉樹的計數(shù)算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹遍歷算法詳解【先序、中序、后序】
- JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹實現(xiàn)查找最小值、最大值、給定值算法示例
- JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之檢索算法實例分析【順序查找、最大最小值、自組織查詢】
- JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹添加/刪除節(jié)點操作示例
相關(guān)文章
postcss-pxtorem實現(xiàn)頁面自適應(yīng)的原理解析
postcss-pxtorem是一個PostCSS插件,用于將CSS中的像素值轉(zhuǎn)換為rem單位,以實現(xiàn)響應(yīng)式布局和適配不同屏幕尺寸的需求,本文給大家介紹postcss-pxtorem實現(xiàn)頁面自適應(yīng)的原理解析,感興趣的朋友一起看看吧2023-12-12
CheckBox多選取值及判斷CheckBox選中是否為空的實例
下面小編就為大家?guī)硪黄狢heckBox多選取值及判斷CheckBox選中是否為空的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
javascript 跨瀏覽器開發(fā)經(jīng)驗總結(jié)(五) js 事件
javascript 跨瀏覽器開發(fā)之js 事件的兼容性問題,需要的朋友可以參考下。2010-05-05
關(guān)于微信小程序中使用wx.getLocation獲取當前詳細位置并計算距離
這篇文章主要介紹了關(guān)于微信小程序中使用wx.getLocation獲取當前詳細位置并計算距離,wx.getLocation只能夠獲取經(jīng)緯度,不能夠拿到詳細地址,這里使用騰訊地圖的api,需要的朋友可以參考下2023-04-04
javascript動態(tài)控制服務(wù)器控件實例
在頁面中放入一個DropDownList控件,并添加一項,用來分析其產(chǎn)生的HTML代碼,這樣在使用js進行動態(tài)控制時,將會非常清晰2014-09-09

