PHPで非常に大きな配列の中央値を見つける方法
PHP では、中央値を求めるなど、非常に大きな配列を処理する必要がある場合があります。ただし、非常に大きな配列の場合、従来の並べ替え方法を使用すると、非常に時間とメモリを消費します。では、非常に大きな配列の中央値を見つけるより効率的な方法はあるのでしょうか?この記事では、高速選択アルゴリズムに基づいた効率的な解決方法を紹介します。
- クイック選択アルゴリズムの概要
クイック選択アルゴリズムは、クイック ソート アルゴリズムに基づいて改良されたアルゴリズムです。その主なアイデアは、順序付けされていない配列内の項目を次の方法で検索することです。急速除算 k 番目に小さい要素。その時間計算量は O(n) であり、従来の並べ替えアルゴリズムの時間計算量 O(n log n) よりも効率的です。
クイック選択アルゴリズムの基本的な手順は次のとおりです:
- ピボット要素 pivot (通常は配列の最初の要素) を選択します。配列内の要素 要素は 2 つの部分に分割されます: pivot より小さい部分と pivot より大きい部分;
- pivot より小さい要素の数が k 未満の場合は、要素の中から k 番目の要素を検索し続けます。ピボットより大きい;
- If より小さい場合 ピボット要素の数が k 以上の場合、ピボットより小さい要素の中から k 番目の要素を検索し続けます;
- 繰り返しk 番目の要素が見つかるまで上記の手順を繰り返します。
- 非常に大きな配列の中央値を見つける
- 次に、高速選択アルゴリズムを使用して非常に大きな配列の中央値を見つける方法を検討します。非常に大きな配列 $nums$ があり、その中央値を見つける必要があるとします。まず、$nums$ に対して簡単な除算を実行し、要素をピボットより小さい部分とピボットより大きい 2 つの部分に分割します。ピボットが配列のちょうど中央にある場合、それは中央値です。それ以外の場合は、ピボットの位置に基づいて、ピボットが配置されている側で検索を続行する必要があると判断できます。
以下はアルゴリズムの詳細な手順です:
まず、中央値の中央値の位置を決定する必要があります。配列内の要素 $n$ の数が奇数の場合、中央値は $nums[(n-1)/2]$ になります。要素の数 $n$ が偶数の場合、中央値は $( nums[n /2-1] nums[n/2])/2$。- 配列 $nums$ をすばやく分割し、ピボット位置 $pos$ を記録します。
- posとmidの位置関係に基づいて、中央値がピボットの左側にあるのか右側にあるのかを判断します。 $pos
- 中央値が見つかるまで手順 2 と 3 を繰り返します。
- 以下は、対応する PHP コード実装です:
function quickSelect($nums, $k) { $n = count($nums); $left = 0; $right = $n - 1; $mid = ($n - 1) / 2; while (true) { $pos = partition($nums, $left, $right); if ($pos == $mid) { if ($n % 2 == 0) { // 偶数个元素 return ($nums[$pos] + $nums[$pos + 1]) / 2; } else { // 奇数个元素 return $nums[$pos]; } } elseif ($pos < $mid) { $left = $pos + 1; } else { $right = $pos - 1; } } } function partition(&$nums, $left, $right) { $pivot = $nums[$left]; $i = $left; $j = $right; while ($i < $j) { while ($i < $j && $nums[$j] >= $pivot) { $j--; } while ($i < $j && $nums[$i] <= $pivot) { $i++; } if ($i < $j) { $temp = $nums[$i]; $nums[$i] = $nums[$j]; $nums[$j] = $temp; } } // 将pivot元素放到正确的位置 $nums[$left] = $nums[$i]; $nums[$i] = $pivot; return $i; } // 测试示例 $nums = array(1, 2, 3, 4, 5, 6, 7, 8, 9); echo quickSelect($nums, 5); // 输出5(因为5在数组中的中间位置)
- 非常に大きな配列の場合、従来の並べ替え方法を使用すると、非常に高度な時間と空間の複雑さ。高速選択アルゴリズムを使用して k 番目に小さい要素を見つけることにより、O(n) 時間の計算量内で演算を完了でき、それによって非常に大きな配列の中央値に対する効率的な解を得ることができます。実際の使用においては、枝刈りなどのさまざまなニーズに応じて適切な最適化を行う必要もあります。
以上がPHPで非常に大きな配列の中央値を見つける方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

ホットトピック









PHP 8のJITコンピレーションは、頻繁に実行されるコードをマシンコードにコンパイルし、重い計算でアプリケーションに利益をもたらし、実行時間を短縮することにより、パフォーマンスを向上させます。

この記事では、コードインジェクションのような脆弱性を防ぐために、PHPファイルのアップロードを確保することについて説明します。ファイルタイプの検証、セキュアストレージ、およびアプリケーションセキュリティを強化するエラー処理に焦点を当てています。

この記事では、PHPおよび緩和戦略におけるOWASPトップ10の脆弱性について説明します。重要な問題には、PHPアプリケーションを監視および保護するための推奨ツールを備えたインジェクション、認証の壊れ、XSSが含まれます。

この記事では、不正アクセスを防ぎ、ベストプラクティスの詳細、セキュリティ強化ツールの推奨を防ぐために、PHPで堅牢な認証と承認の実装について説明します。

この記事では、PHPの対称的および非対称暗号化について説明し、適合性、パフォーマンス、セキュリティの違いを比較しています。対称暗号化はより速く、バルクデータに適していますが、非対称は安全なキー交換に使用されます。

PHPの準備されたステートメントは、SQLインジェクションを防止し、コンピレーションと再利用を通じてクエリパフォーマンスを改善することにより、データベースのセキュリティと効率を強化します。

この記事では、Token BucketやLeaky BucketなどのアルゴリズムやSymfony/Rate-Limiterなどのライブラリを使用するなど、PHPでAPIレート制限を実装するための戦略について説明します。また、監視、動的に調整されたレートの制限、および手をカバーします

記事では、PHPを使用してデータベースからデータを取得し、手順、セキュリティ対策、最適化手法、およびソリューションを使用した一般的なエラーをカバーしています。
