アルゴリズム - 検索をスキップ
たとえば、サイズ 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 サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











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

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

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

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

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

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

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