国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹插入節(jié)點、生成二叉樹示例

2019-11-19 12:05:14
字體:
供稿:網(wǎng)友

本文實例講述了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.VeVB.COm/code/HtmlJsRun測試上述代碼,可得如下運行結(jié)果:

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)學運算用法總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 汉川市| 华阴市| 涿州市| 邮箱| 交口县| 英吉沙县| 凤庆县| 灯塔市| 井研县| 金昌市| 乌恰县| 衡水市| 绥芬河市| 兴山县| 夏津县| 黄梅县| 兴国县| 利辛县| 巩留县| 博罗县| 梧州市| 香港 | 虎林市| 江孜县| 麻城市| 呼图壁县| 宁波市| 琼结县| 伽师县| 麻阳| 虹口区| 临江市| 上林县| 福安市| 三亚市| 霍山县| 乐都县| 孝昌县| 巴中市| 灵武市| 广河县|