ホームページ システムチュートリアル Linux アルゴリズム - 検索をスキップ

アルゴリズム - 検索をスキップ

Feb 16, 2024 am 10:42 AM
linux Linuxチュートリアル レッドハット Linuxシステム Linuxコマンド Linux 認定 レッドハットリナックス Linuxビデオ

アルゴリズム - 検索をスキップ

たとえば、サイズ n の配列 arr[] とサイズ m のブロック (ジャンプ対象) があるとします。次に、インデックス arr[0]、arr[m]、arr[2m]... ..arr[km] などを検索します。間隔を見つけたら (arr [km]

次の配列を検討します: (0,1,1,2,3,5,8,13,21,34,55,89,144,233,377,610)。配列の長さは 16 です。スキップされるブロック サイズが 4 であると仮定すると、スキップ検索では次の手順で 55 が見つかります。

ステップ 1: インデックス 0 からインデックス 4 にジャンプします;
ステップ 2: インデックス 4 からインデックス 8 にジャンプします;
ステップ 3: インデックス 8 からインデックス 16 にジャンプします;
ステップ 4: インデックス 16 の要素は 55 より大きいため、インデックス 9 まで 1 ステップ戻ります。 ステップ 5: インデックス 9 から線形検索を実行して要素 55 を取得します。

スキップする最適なブロック サイズはどれくらいですか? 最悪の場合、最後にチェックされた値が検索対象の要素より大きい場合、n/m ジャンプを実行し、線形検索で m-1 比較を実行する必要があります。したがって、最悪の場合の合計比較数は ((n/m)m-1) になります。 m=√nのとき、関数((n/m)m-1)の値が最小値となります。したがって、最適なステップ サイズは m = √n です。
リーリー

出力:

番号 55 はインデックス 10 にあります

時間計算量: O(√n)

補助スペース: O(1)
######知らせ:######

この検索は、ソートされた配列に対してのみ機能します。

スキップするチャンクの最適なサイズは O(√n) です。これにより、ジャンプ検索の時間計算量は O(√n) になります。 スキップ検索の時間計算量は、線形検索 ((O(n))) と二分検索 (O(Log n)) の間です。 バイナリ検索はジャンプ検索より優れていますが、ジャンプ検索には 1 回だけトラバースできるという利点があります (バイナリ検索では、検索対象の要素が最小要素または最小要素未満であることを考慮すると、最大 0 (Log n) 回のジャンプが必要になる場合があります)。したがって、ジャンプバックにコストがかかるシステムでは、ジャンプ検索を使用します。

以上がアルゴリズム - 検索をスキップの詳細内容です。詳細については、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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Linuxアーキテクチャ:5つの基本コンポーネントを発表します Linuxアーキテクチャ:5つの基本コンポーネントを発表します Apr 20, 2025 am 12:04 AM

Linuxシステムの5つの基本コンポーネントは次のとおりです。1。Kernel、2。Systemライブラリ、3。Systemユーティリティ、4。グラフィカルユーザーインターフェイス、5。アプリケーション。カーネルはハードウェアリソースを管理し、システムライブラリは事前コンパイルされた機能を提供し、システムユーティリティはシステム管理に使用され、GUIは視覚的な相互作用を提供し、アプリケーションはこれらのコンポーネントを使用して機能を実装します。

GITの倉庫アドレスを確認する方法 GITの倉庫アドレスを確認する方法 Apr 17, 2025 pm 01:54 PM

gitリポジトリアドレスを表示するには、次の手順を実行します。1。コマンドラインを開き、リポジトリディレクトリに移動します。 2。「git remote -v」コマンドを実行します。 3.出力と対応するアドレスでリポジトリ名を表示します。

Apr 16, 2025 pm 07:39 PM

NotePadはJavaコードを直接実行することはできませんが、他のツールを使用することで実現できます。コマンドラインコンパイラ(Javac)を使用してByteCodeファイル(filename.class)を生成します。 Javaインタープリター(Java)を使用して、バイトコードを解釈し、コードを実行し、結果を出力します。

コードを書いた後に崇高に実行する方法 コードを書いた後に崇高に実行する方法 Apr 16, 2025 am 08:51 AM

Sublimeでコードを実行するには6つの方法があります。ホットキー、メニュー、ビルドシステム、コマンドライン、デフォルトビルドシステムの設定、カスタムビルドコマンド、プロジェクト/ファイルを右クリックして個々のファイル/プロジェクトを実行します。ビルドシステムの可用性は、崇高なテキストのインストールに依存します。

Linuxの主な目的は何ですか? Linuxの主な目的は何ですか? Apr 16, 2025 am 12:19 AM

Linuxの主な用途には、1。Serverオペレーティングシステム、2。EmbeddedSystem、3。Desktopオペレーティングシステム、4。開発およびテスト環境。 Linuxはこれらの分野で優れており、安定性、セキュリティ、効率的な開発ツールを提供します。

Laravelインストールコード Laravelインストールコード Apr 18, 2025 pm 12:30 PM

Laravelをインストールするには、これらの手順を順番に進みます。コンポーザー(MacOS/LinuxとWindows用)インストールLaravelインストーラーをインストールします。

GITソフトウェアのインストール GITソフトウェアのインストール Apr 17, 2025 am 11:57 AM

GITソフトウェアのインストールには、次の手順が含まれています。インストールパッケージをダウンロードしてインストールパッケージを実行して、インストール構成gitインストールgitバッシュ(Windowsのみ)を確認します

Apr 16, 2025 am 08:57 AM

崇高なテキストは、一般的に使用される(保存、コピー、カットなど)、編集(インデント、フォーマットなど)、ナビゲーション(プロジェクトパネル、ファイルブラウジングなど)、ショートカットの検索と交換など、開発効率を改善するためのショートカットを提供します。これらのショートカットキーを使用する習熟度は、Sublimeの効率を大幅に改善できます。

See all articles