コンテンツにスキップ
メインメニュー
メインメニュー
サイドバーに移動
非表示
案内
メインページ
最近の更新
未作成ページ
おまかせ表示
ヘルプ
MonoBook
検索
検索
ログイン
個人用ツール
ログイン
ログアウトした編集者のページ
もっと詳しく
投稿記録
トーク
「
二分探索木
」を編集中
ページ
議論
日本語
閲覧
編集
ソースを編集
履歴表示
ツール
ツール
サイドバーに移動
非表示
操作
閲覧
編集
ソースを編集
履歴表示
全般
リンク元
関連ページの更新状況
特別ページ
ページ情報
警告:
ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。
ログイン
または
アカウントを作成
すれば、あなたの編集はその利用者名とともに表示されるほか、その他の利点もあります。
スパム攻撃防止用のチェックです。 けっして、ここには、値の入力は
しない
でください!
'''二分探索木'''とは、大小関係を決めることができる[[データ]]の挿入と検索を[[オーダー|O]](log N)でできることを期待した[[データ構造]]である。 [[木|根つき木]]で表され、ある要素の子は必ず2個以下である。また、子に順番の区別がある。 [[ファイル:Binary_search_tree.png|thumb|right|二分探索木の例]] ==データ操作== ===挿入=== # 木の根に注目する。根が無ければ、挿入するデータを根にして終了する。 # 今注目している要素のデータと挿入するデータを比較する。 # 挿入するデータが今注目している要素のデータより大きければ右の子へ、小さければ左の子へ注目を移す。 # 注目しようとした子が無ければ、その位置に挿入するデータを子として置き、終了する。 # 注目を移したら、2に戻る。以下、繰り返す。 挿入するデータと今注目している要素のデータが同じだった場合、目的の処理によって、 挿入するデータを破棄する、注目している要素に関連付けられた値を書き換える([[連想配列]]の場合)、 あらかじめ左または右に行くと決めておく、などの処理が考えられる。 ===検索=== # 木の根に注目する。根がなければ、見つからなかったとして終了する。 # 今注目している要素のデータと検索したいデータを比較する。 # 検索したいデータと今注目している要素のデータが同じなら、見つかったとして終了する。 # 検索したいデータが今注目している要素のデータより大きいなら右の子へ、小さければ左の子へ注目を移す。 # 注目しようとした子がなければ、見つからなかったとして終了する。 # 注目を移したら、2に戻る。以下、繰り返す。 ==長所== * [[実装]]が比較的単純 * [[ランダム]]なデータに対しては、ほぼO(log 挿入されたデータ数)で挿入と検索ができる ==短所== * [[昇順]]や[[降順]]にデータが挿入されると、挿入や検索にO(挿入されたデータ数^2)かかってしまう ==関連項目== * [[平衡二分探索木]] * [[ハッシュテーブル]] * [[データ構造]]
編集内容の要約:
MonoBookへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細は
MonoBook:著作権
を参照)。
著作権保護されている作品は、許諾なしに投稿しないでください!
このページを編集するには、下記の確認用の質問に回答してください (
詳細
):
1たす1は?(全角で入力してください)
キャンセル
編集の仕方
(新しいウィンドウで開きます)
本文の横幅制限を有効化/無効化