Javascriptの二分探索木

Aug 09, 2024 am 09:13 AM

JavaScript での二分探索ツリーの実装

この投稿では、JavaScript で基本的な二分探索ツリー (BST) を実装する方法を検討します。ノードの挿入と、順序、事前順序、事後順序などのさまざまなツリー走査方法の実行について説明します。

ノードクラス
まず、ツリー内の各ノードを表す Node クラスを定義しましょう:

class Node {
    constructor(value) {
        this.value = value;
        this.left = null;
        this.right = null;
    }
}
ログイン後にコピー

各 Node オブジェクトには 3 つのプロパティがあります:

  • : ノードに保存されているデータ。
  • left: 左の子ノードへのポインタ。
  • right: 右の子ノードへのポインタ。

BinarySearchTree クラス

次に、ノードを管理し、ツリーと対話するメソッドを提供する BinarySearchTree クラスを定義します。

class BinarySearchTree {
    constructor() {
        this.root = null;
    }

    isEmpty() {
        return this.root === null;
    }

    insertNode(root, newNode) {
        if(newNode.value < root.value) {
            if(root.left === null) {
                root.left = newNode;
            } else {
                this.insertNode(root.left, newNode);
            }
        } else {
            if(root.right === null) {
                root.right = newNode;
            } else {
                this.insertNode(root.right, newNode);
            }
        }
    }

    search(root, value) {
        if(!root) {
            return false;
        }
        if(root.value === value) {
            return true;
        } else if(root.value > value) {
            return this.search(root.left, value);
        } else {
            return this.search(root.right, value);
        }
    }

    insert(value) {
        const newNode = new Node(value);
        if(this.isEmpty()) {
            this.root = newNode;
        } else {
            this.insertNode(this.root, newNode);
        }
    }
}
ログイン後にコピー

主要メソッド:

  • isEmpty(): ツリーが空かどうかを確認します。
  • insertNode(root, newNode): 二分探索ツリーのプロパティを維持しながら、新しいノードをツリーに挿入します。
  • search(root, value): ツリー内の値を再帰的に検索します。
  • insert(value): ツリーに新しい値を挿入する便利なメソッドです。

ツリートラバーサルメソッド

ツリーを作成したら、多くの場合、それを横断する必要があります。以下に 3 つの一般的な走査方法を示します:

順番トラバーサル

インオーダートラバーサルは、左、ルート、右の順序でノードを訪問します。

inOrder(root) {
    if(root) {
        this.inOrder(root.left);
        console.log(root.value);
        this.inOrder(root.right);
    }
}
ログイン後にコピー

この走査は、二分探索ツリーのノードを非降順で出力します。

事前注文トラバーサル

事前順序トラバーサルは、ルート、左、右の順序でノードを訪問します。

preOrder(root) {
    if(root) {
        console.log(root.value);
        this.preOrder(root.left);
        this.preOrder(root.right);
    }
}
ログイン後にコピー

この走査は、ツリー構造をコピーするのに役立ちます。

事後トラバーサル

ポストオーダートラバーサルは、左、右、ルートの順序でノードを訪問します。

postOrder(root) {
    if(root) {
        this.postOrder(root.left);
        this.postOrder(root.right);
        console.log(root.value);
    }
}
ログイン後にコピー

この走査は、ノードの削除または解放によく使用されます。

使用例

Binary Search Tree in Javascript

これらのメソッドがどのように連携して機能するかを見てみましょう:

const bst = new BinarySearchTree();
bst.insert(10);
bst.insert(5);
bst.insert(20);
bst.insert(3);
bst.insert(7);

console.log('In-order Traversal:');
bst.inOrder(bst.root);

console.log('Pre-order Traversal:');
bst.preOrder(bst.root);

console.log('Post-order Traversal:');
bst.postOrder(bst.root);
ログイン後にコピー

結論

この実装により、JavaScript で二分探索ツリーを作成し、操作できるようになりました。ツリー構造と走査方法を理解することは、多くのアルゴリズムの問​​題、特に検索アルゴリズム、式の解析、階層データの管理などの分野において重要です。

以上がJavascriptの二分探索木の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JavaScriptの文字列文字を交換します JavaScriptの文字列文字を交換します Mar 11, 2025 am 12:07 AM

JavaScriptの文字列文字を交換します

jQuery日付が有効かどうかを確認します jQuery日付が有効かどうかを確認します Mar 01, 2025 am 08:51 AM

jQuery日付が有効かどうかを確認します

jQueryは要素のパディング/マージンを取得します jQueryは要素のパディング/マージンを取得します Mar 01, 2025 am 08:53 AM

jQueryは要素のパディング/マージンを取得します

10 jQuery Accordionsタブ 10 jQuery Accordionsタブ Mar 01, 2025 am 01:34 AM

10 jQuery Accordionsタブ

10 jqueryプラグインをチェックする価値があります 10 jqueryプラグインをチェックする価値があります Mar 01, 2025 am 01:29 AM

10 jqueryプラグインをチェックする価値があります

ノードとHTTPコンソールを使用したHTTPデバッグ ノードとHTTPコンソールを使用したHTTPデバッグ Mar 01, 2025 am 01:37 AM

ノードとHTTPコンソールを使用したHTTPデバッグ

カスタムGoogle検索APIセットアップチュートリアル カスタムGoogle検索APIセットアップチュートリアル Mar 04, 2025 am 01:06 AM

カスタムGoogle検索APIセットアップチュートリアル

jQueryはscrollbarをdivに追加します jQueryはscrollbarをdivに追加します Mar 01, 2025 am 01:30 AM

jQueryはscrollbarをdivに追加します

See all articles