首頁 web前端 js教程 javascript演算法之二元搜尋樹的範例程式碼

javascript演算法之二元搜尋樹的範例程式碼

Jan 23, 2018 am 11:12 AM
javascript js 範例

這篇文章主要介紹了javascript演算法之二元搜尋樹的範例程式碼,具有一定的參考和學習JavaScript的價值,對JavaScript感興趣的小夥伴們可以參考一下本篇文章

什麼是二元樹

二元樹就是樹的每個節點最多只能有兩個子節點

什麼是二元搜尋樹

二元搜尋樹在二元樹的基礎上,多了一個條件,就是二元樹在插入值時,若插入值比當前節點小,就插入到左節點,否則插入到右節點;若插入過程中,左節點或右節點已經存在,那麼繼續如上規則比較,直到遇到新的節點。

二元搜尋樹的特性

二元搜尋樹由於其獨特的資料結構,使得其無論在增刪,還是查找,時間複雜度都是O (h),h為二元樹的高度。因此二元樹應該盡量的矮,即左右節點盡量平衡。

二元搜尋樹的建構

要建構二元搜尋樹,首先要建構二元樹的節點類別。由二元樹的特徵可知,每個節點類別都有一個左節點,右節點以及值本身,因此節點類別如下:

class Node {
 constructor(key) {
  this.key = key;
  this.left = null;
  this.right = null;
 }
}
登入後複製

接著建構二元搜尋樹

class Tree{
 constructor(param = null) {
  if (param) {
   this.root = new Node(param);
  } else {
   this.root = null;
  }
 }
}
登入後複製

這裡this. root就是當前物件的樹。

二元搜尋樹的新增

由二元搜尋樹左子樹比節點小,右子樹別節點大的特點,可以很簡單的寫出二元搜尋樹新增的演算法,如下:

insert(key) {
 if (this.root === null) {
  this.root = new Node(key);
 } else {
  this._insertNode(this.root, key);
 }
}
_insertNode(node, key) {
 if (key < node.key) {
  if (node.left === null) {
   node.left = new Node(key);{1}
  } else {
   this._insertNode(node.left, key);{2}
  }
 } else if (key > node.key) {
  if (node.right === null) {
   node.right = new Node(key);{3}
  } else {
   this._insertNode(node.right, key);{4}
  }
 }
}
登入後複製

如上程式碼先判斷新增的key與目前節點的key大小,如果小,就遞歸遍歷左子節點,直到找到一個為null的左子節點;如果比目前節點大同理。如上程式碼{1}{2}{3}{4}之所以能改變this.root的值,是由於JavaScript函數是按值傳遞,而當參數是非基本型別時,例如這裡的對象,其對象的值為內存,因此每次都會直接改變this.root的內容。

二元搜尋樹的遍歷

二元搜尋樹分為先序、中序、後序三種遍歷方式。

inOrderTraverse(callback) {
 this._inOrderTraverse(this.root, callback);
}
_inOrderTraverse(node, callback) {
 if (node) {
  this._inOrderTraverse(node.left, callback);
  callback(node.key);
  this._inOrderTraverse(node.right, callback);
 }
}
登入後複製

如上是中序遍歷。

這裡需要理解的一點是遞歸。要知道,函數的執行可以抽象化為一種資料結構——棧。針對函數的執行,會維護一個棧,來儲存函數的執行。函數在每一次遞歸時,都會將目前的執行環境入堆疊並記錄執行的位置。以上述程式碼為例,有以下一個資料

其會從11開始,執行{1}入棧,然後進入7,接著執行{1}入棧,然後到5,執行{1}入棧,再到3,執行{1}入棧,此時發現節點3的左子節點為null,因此開始出棧,此時彈出節點3的執行環境,執行{2},{3},發現3的右側子節點也是null,{3}的遞歸執行完畢,接著彈出節點5,執行{2}{3},接著彈出7,執行{2}{3}入棧,執行{3}時,發現節點7有右節點,因此繼續執行{1},到節點8,再執行{1},8沒有左子節點,{1}執行完畢,執行{2}{3},以此類推。

而前序與中序的不同點在於其先存取節點本身,也就是程式碼的執行順序為 2 1 3。

後序同理,執行順序為1 3 2

不難發現,無論前中後序,永遠都是先遞歸左節點,當左節點遍歷完畢再彈出棧,遍歷有節點。他們唯一不同的點在與訪問該節點本身的時機。

二元搜尋樹的查找

查找很簡單,根據左子節點比該節點小,右子節點比該節點大的原則進行循環判斷即可。

search(value) {
 if (this.root) {
  if (value === this.root.key) {
   return true;
  } else {
   return this._searchNode(value, this.root);
  }
 }
 throw new Error(&#39;this.root 不存在&#39;);
}
_searchNode(value, node) {
 if (!node) {
  return false;
 }
 if (value === node.key) {
  return true;
 }
 if (value > node.key) {
  return this._searchNode(value, node.right);
 } else if (value < node.key) {
  return this._searchNode(value, node.left);
 }
}
登入後複製

二元搜尋樹的刪除

刪除較為複雜,需要根據不同情況判斷

先判斷該節點是否有左子樹,如果沒有左子節樹,則直接將右子樹的根節點替換被刪除節點;

如果有,則將右子樹的最小節點替換被刪除節點;

remove(key) {
 this._removeNode(this.root, key);
}
_removeNode(node, value) {
 if (!node) {
  return null;
 }
 if (value > node.key) {
  node.right = this._removeNode(node.right, value);
 } else if (value < node.key) {
  node.left = this._removeNode(node.left, value);
 } else {
  // 如果没有左子树,那么将右子树根节点作为替换节点
  if (!node.left) {
   return node.right;
   // 如果存在左子树,那么取右子树最小节点作为替换节点
  } else if (node.left) {
   return this._minNode(node.right);
  }
 }
}
登入後複製

總結

總的來說,透過這次簡單的二元搜尋樹的學習,讓我重新認識了遞歸,以前對於遞歸的理解只是一些簡單的理論概念,這次深入實踐讓我對遞歸的理解又加深了許多。

這讓我想到了數學的學習,數學的理論公式是很容易記住掌握的,如果說對一個知識點的掌握滿分是十分,那麼直到真正去實踐它之前,只看公式的掌握只能是2分,因為公式很簡單,就幾句話幾個原則,但是遇到的問題是千變萬化的,只有真正將理論付諸實踐,經過各種實踐的打磨蹂躪,才能真正理解它其中的奧秘。

相關推薦:

三種JavaScript模擬實作封裝的方式及寫法區別分享

詳解JavaScript自執行函數與jQuery擴充方法

JavaScript中Require呼叫js實例講解

以上是javascript演算法之二元搜尋樹的範例程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

建議:優秀JS開源人臉偵測辨識項目 建議:優秀JS開源人臉偵測辨識項目 Apr 03, 2024 am 11:55 AM

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

Oracle DECODE函數詳解及用法範例 Oracle DECODE函數詳解及用法範例 Mar 08, 2024 pm 03:51 PM

Oracle中的DECODE函數是一種條件式,常用於在查詢語句中根據不同的條件傳回不同的結果。本文將詳細介紹DECODE函數的語法、用法和範例程式碼。一、DECODE函數語法DECODE(expr,search1,result1[,search2,result2,...,default])expr:要進行比較的表達式或欄位。 search1,

Go語言的縮排規範及範例 Go語言的縮排規範及範例 Mar 22, 2024 pm 09:33 PM

Go语言的缩进规范及示例Go语言是一种由Google开发的编程语言,它以简洁、清晰的语法著称,其中缩进规范在代码的可读性和美观性方面起着至关重要的作用。本文将介绍Go语言的缩进规范,并通过具体的代码示例进行详细说明。缩进规范在Go语言中,缩进使用制表符(tab)而非空格。每级缩进为一个制表符,通常设置为4个空格的宽度。这样的规范统一了代码风格,使得团队合作编

PHP與JS開發技巧:掌握繪製股票蠟燭圖的方法 PHP與JS開發技巧:掌握繪製股票蠟燭圖的方法 Dec 18, 2023 pm 03:39 PM

隨著網路金融的快速發展,股票投資已經成為了越來越多人的選擇。而在股票交易中,蠟燭圖是常用的技術分析方法,它能夠顯示股票價格的變動趨勢,幫助投資人做出更精準的決策。本文將透過介紹PHP和JS的開發技巧,帶領讀者了解如何繪製股票蠟燭圖,並提供具體的程式碼範例。一、了解股票蠟燭圖在介紹如何繪製股票蠟燭圖之前,我們首先需要先了解什麼是蠟燭圖。蠟燭圖是由日本人

簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

js和vue的關係 js和vue的關係 Mar 11, 2024 pm 05:21 PM

js和vue的關係:1、JS作為Web開發基石;2、Vue.js作為前端框架的崛起;3、JS與Vue的互補關係;4、JS與Vue的實踐應用。

PHP 點運算子的運用與實例分析 PHP 點運算子的運用與實例分析 Mar 28, 2024 pm 12:06 PM

PHP點運算子的運用與實例分析在PHP中,點運算子(「.」)是用來連接兩個字串的運算符,它在字串拼接時非常常用且十分靈活。透過使用點運算符,我們可以方便地將多個字串連接起來,構成一個新的字串。以下將透過實例分析來介紹PHP點操作符的運用。一、基本使用方法首先,我們來看一個基本的使用實例。假設有兩個變數$str1和$str2,分別儲存了兩個字

如何在JavaScript中取得HTTP狀態碼的簡單方法 如何在JavaScript中取得HTTP狀態碼的簡單方法 Jan 05, 2024 pm 01:37 PM

JavaScript中的HTTP狀態碼取得方法簡介:在進行前端開發中,我們常常需要處理與後端介面的交互,而HTTP狀態碼就是其中非常重要的一部分。了解並取得HTTP狀態碼有助於我們更好地處理介面傳回的資料。本文將介紹使用JavaScript取得HTTP狀態碼的方法,並提供具體程式碼範例。一、什麼是HTTP狀態碼HTTP狀態碼是指當瀏覽器向伺服器發起請求時,服務

See all articles