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

首頁 > 編程 > JavaScript > 正文

JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹遍歷算法詳解【先序、中序、后序】

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

本文實(shí)例講述了JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之二叉樹遍歷算法。分享給大家供大家參考,具體如下:

javascript數(shù)據(jù)結(jié)構(gòu)與算法--二叉樹遍歷(先序)

先序遍歷先訪問根節(jié)點(diǎn), 然后以同樣方式訪問左子樹和右子樹

代碼如下:

/* *二叉樹中,相對(duì)較小的值保存在左節(jié)點(diǎn)上,較大的值保存在右節(jié)點(diǎn)中 * * * *//*用來生成一個(gè)節(jié)點(diǎn)*/function Node(data, left, right) {  this.data = data;//節(jié)點(diǎn)存儲(chǔ)的數(shù)據(jù)  this.left = left;  this.right = right;  this.show = show;}function show() {  return this.data;}/*用來生成一個(gè)二叉樹*/function BST() {  this.root = null;  this.insert = insert;}/*將數(shù)據(jù)插入二叉樹 (1)設(shè)根節(jié)點(diǎn)為當(dāng)前節(jié)點(diǎn)。 (2)如果待插入節(jié)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn);反 之,執(zhí)行第4步。 (3)如果當(dāng)前節(jié)點(diǎn)的左節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(huán);反之,繼續(xù) 執(zhí)行下一次循環(huán)。 (4)設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的右節(jié)點(diǎn)。 (5)如果當(dāng)前節(jié)點(diǎn)的右節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(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é)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn)        if (current == null) {//如果當(dāng)前節(jié)點(diǎn)的左節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(huán);反之,繼續(xù)執(zhí)行下一次while循環(huán)。          parent.left = n;          break;        }      }      else {        current = current.right;//待插入節(jié)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn)        if (current == null) {          parent.right = n;          break;        }      }    }  }}/*先序遍歷 *用遞歸的方法 */function preOrder(node) {  if (!(node == null)) {    console.log(node.show() + " ");    preOrder(node.left);    preOrder(node.right);  }}/* 測(cè)試代碼 */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("先序遍歷: ");preOrder(nums.root);

運(yùn)行結(jié)果:

javascript數(shù)據(jù)結(jié)構(gòu)與算法--二叉樹遍歷(中序)

中序遍歷按照節(jié)點(diǎn)上的鍵值,以升序訪問BST上的所有節(jié)點(diǎn)

代碼如下:

/* *二叉樹中,相對(duì)較小的值保存在左節(jié)點(diǎn)上,較大的值保存在右節(jié)點(diǎn)中 * * * *//*用來生成一個(gè)節(jié)點(diǎn)*/function Node(data, left, right) {  this.data = data;//節(jié)點(diǎn)存儲(chǔ)的數(shù)據(jù)  this.left = left;  this.right = right;  this.show = show;}function show() {  return this.data;}/*用來生成一個(gè)二叉樹*/function BST() {  this.root = null;  this.insert = insert;}/*將數(shù)據(jù)插入二叉樹 (1)設(shè)根節(jié)點(diǎn)為當(dāng)前節(jié)點(diǎn)。 (2)如果待插入節(jié)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn);反 之,執(zhí)行第4步。 (3)如果當(dāng)前節(jié)點(diǎn)的左節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(huán);反之,繼續(xù) 執(zhí)行下一次循環(huán)。 (4)設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的右節(jié)點(diǎn)。 (5)如果當(dāng)前節(jié)點(diǎn)的右節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(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é)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn)        if (current == null) {//如果當(dāng)前節(jié)點(diǎn)的左節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(huán);反之,繼續(xù)執(zhí)行下一次while循環(huán)。          parent.left = n;          break;        }      }      else {        current = current.right;//待插入節(jié)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn)        if (current == null) {          parent.right = n;          break;        }      }    }  }}/*中序遍歷*用遞歸的方法*/function inOrder(node) {  if (!(node == null)) {    inOrder(node.left);    console.log(node.show() + " ");    inOrder(node.right);  }}/* 測(cè)試代碼 */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("中序遍歷: ");inOrder(nums.root);

運(yùn)行結(jié)果:

javascript數(shù)據(jù)結(jié)構(gòu)與算法--二叉樹遍歷(后序)

后序遍歷先訪問葉子節(jié)點(diǎn),從左子樹到右子樹,再到根節(jié)點(diǎn)。

/* *二叉樹中,相對(duì)較小的值保存在左節(jié)點(diǎn)上,較大的值保存在右節(jié)點(diǎn)中 * * * *//*用來生成一個(gè)節(jié)點(diǎn)*/function Node(data, left, right) {  this.data = data;//節(jié)點(diǎn)存儲(chǔ)的數(shù)據(jù)  this.left = left;  this.right = right;  this.show = show;}function show() {  return this.data;}/*用來生成一個(gè)二叉樹*/function BST() {  this.root = null;  this.insert = insert;}/*將數(shù)據(jù)插入二叉樹 (1)設(shè)根節(jié)點(diǎn)為當(dāng)前節(jié)點(diǎn)。 (2)如果待插入節(jié)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn);反 之,執(zhí)行第4步。 (3)如果當(dāng)前節(jié)點(diǎn)的左節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(huán);反之,繼續(xù) 執(zhí)行下一次循環(huán)。 (4)設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的右節(jié)點(diǎn)。 (5)如果當(dāng)前節(jié)點(diǎn)的右節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(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é)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn)        if (current == null) {//如果當(dāng)前節(jié)點(diǎn)的左節(jié)點(diǎn)為null,就將新的節(jié)點(diǎn)插入這個(gè)位置,退出循環(huán);反之,繼續(xù)執(zhí)行下一次while循環(huán)。          parent.left = n;          break;        }      }      else {        current = current.right;//待插入節(jié)點(diǎn)保存的數(shù)據(jù)小于當(dāng)前節(jié)點(diǎn),則設(shè)新的當(dāng)前節(jié)點(diǎn)為原節(jié)點(diǎn)的左節(jié)點(diǎn)        if (current == null) {          parent.right = n;          break;        }      }    }  }}/*后序遍歷 *用遞歸的方法 */function postOrder(node) {  if (!(node == null)) {    postOrder(node.left);    postOrder(node.right);    console.log(node.show() + " ");  }}/* 測(cè)試代碼 */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("后序遍歷: ");postOrder(nums.root);

運(yùn)行結(jié)果:

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具http://tools.VeVB.COm/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

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

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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 宾阳县| 上高县| 临漳县| 清流县| 兴仁县| 北碚区| 班戈县| 曲麻莱县| 汉源县| 大同县| 宁海县| 南充市| 广西| 乌兰察布市| 黔江区| 唐海县| 徐水县| 仪征市| 新郑市| 杂多县| 廊坊市| 舞钢市| 寿光市| 安丘市| 淮南市| 裕民县| 双柏县| 禹城市| 会泽县| 会宁县| 绍兴县| 鸡泽县| 武平县| 北安市| 甘谷县| 建平县| 英吉沙县| 安阳市| 灵宝市| 双柏县| 罗城|