マージソートを実装するための
php メソッド: 1. PHP サンプル ファイルを作成します; 2. 「パブリック関数 handle(){...}」メソッドを定義します; 3. 「プライベート関数 mergeSort($a, $lo, $hi) {...}" メソッドを使用して、データを段階的に分解します。 4. "merge" メソッドを使用して、分解されたデータを並べ替えてから、それらをマージします。
php はマージ ソート アルゴリズムを実装します。
マージ ソート アルゴリズムの複雑さは O(nlogn) です。
コードは次のとおりです。クローンを作成して composer install
を実行してから、php Artisan test:mergeSort
を実行すると、結果が表示されます
/** * 归并排序把数据逐步分解,然后对分解后的数据进行排序,最后合并到一起 * * @return mixed */ public function handle() { $this->a = [3,70,4,38,5,6,8,4,7,10,6,10,34,4]; dump($this->a); $a = $this->mergeSort($this->a, 0, count($this->a)); dd($a); } private function mergeSort($a, $lo, $hi) { if (($hi - $lo) < 2) return [$a[$lo]]; $mi = ($lo + $hi) >> 1; //把中点左边的进行归并 $b = $this->mergeSort($a, $lo, $mi); dump('$b:',$b); //把中点右边的进行归并 $c = $this->mergeSort($a, $mi, $hi); dump('$c:',$c); //把所有数据进行排序 return $this->merge($b, $c, $lo,$mi,$hi); } /** * 假设有一个数组$a分成了两个数组[3,4] [2,8] * 逐一比较,3and2,取出来2然后3and8取出来3然后4and8取出来4,最后取出来8 * * @param [type] $lo * @param [type] $mi * @param [type] $hi * @return void */ private function merge($b, $c, $lo, $mi, $hi) { $lb = $mi - $lo; //$b数组的边界 $lc = $hi - $mi; //$c数组的边界 $res = []; //$i表示合并后数组的下标 $ib是b数组的下标 $ic是c数组的下标 for($i = 0,$ib=0,$ic=0;$ib<$lb || $ic < $lc;){ //ib 下标没有越界 && c的数组已经空了也就是$ic >= $lc || 比较两个数组首位的大小 如果b的首元素 < c的首元素,那么取出来b的首元素 if ($ib < $lb && ( $ic >= $lc || $b[$ib] <= $c[$ic])) { $res[$i++] = $b[$ib++]; } //k 下标没有越界 && b的数组已经空了也就是$ib >= $lb || 如果c的首元素 < b的首元素,那么取出来c的首元素 if ($ic < $lc && ($ib >= $lb || $b[$ib] > $c[$ic])) { $res[$i++] = $c[$ic++]; } } return $res; }
マージ ソートの原理
マージ ソートはクイック ソートの逆で、まず配列全体を左右に分割し、次に 1 つずつマージしてソートし、最後に配列全体のソートを完了します。ソート図は次のとおりです。
最初に、配列全体を左右に分散して 1 つの要素にまとめます。これは、1 つの要素が順序付けされていると見なせるためです。
対応コード
if (($hi - $lo) < 2) return [$a[$lo]]; $mi = ($lo + $hi) >> 1; //把中点左边的进行归并 $b = $this->mergeSort($a, $lo, $mi); dump('$b:',$b); //把中点右边的进行归并 $c = $this->mergeSort($a, $mi, $hi); dump('$c:',$c);
次に、左右の順序配列をソートします。配列 $a が 2 つの配列 [3,4] [ 2, 8]、1 つずつ比較し、3 と 2、2 を取り出し、次に 3 と 8、3 を取り出し、次に 4 と 8、4 を取り出し、最後に 8 を取り出します。対応するコード:
$lb = $mi - $lo; //$b数组的边界 $lc = $hi - $mi; //$c数组的边界 $res = []; //$i表示合并后数组的下标 $ib是b数组的下标 $ic是c数组的下标 for($i = 0,$ib=0,$ic=0;$ib<$lb || $ic < $lc;){ //ib 下标没有越界 && c的数组已经空了也就是$ic >= $lc || 比较两个数组首位的大小 如果b的首元素 < c的首元素,那么取出来b的首元素 if ($ib < $lb && ( $ic >= $lc || $b[$ib] <= $c[$ic])) { $res[$i++] = $b[$ib++]; } //k 下标没有越界 && b的数组已经空了也就是$ib >= $lb || 如果c的首元素 < b的首元素,那么取出来c的首元素 if ($ic < $lc && ($ib >= $lb || $b[$ib] > $c[$ic])) { $res[$i++] = $c[$ic++]; } } return $res;
回路図図は次のとおりです。
推奨学習: 「PHP ビデオ チュートリアル 」
以上がPHPでマージソートを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、酸とベースのデータベースモデルを比較し、その特性と適切なユースケースを詳述しています。酸は、財務およびeコマースアプリケーションに適したデータの整合性と一貫性を優先し、ベースは可用性に焦点を当て、

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

記事では、組み込み関数、ホワイトリストアプローチ、サーバー側の検証などの手法に焦点を当てたセキュリティを強化するためのPHP入力検証のベストプラクティスについて説明します。

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

この記事では、パスワードを保護するためにPHPでpassword_hashとpassword_verifyを使用することの利点について説明します。主な議論は、これらの関数が自動塩の生成、強力なハッシュアルゴリズム、およびSecurを通じてパスワード保護を強化するということです

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

この記事では、PHPでのXSS攻撃を防ぐための戦略について説明し、入力の消毒、出力エンコード、セキュリティを向上させるライブラリとフレームワークの使用に焦点を当てています。

この記事では、PHPでのインターフェイスと抽象クラスの使用について説明し、それぞれをいつ使用するかに焦点を当てています。インターフェイスは、無関係なクラスや複数の継承に適した、実装なしで契約を定義します。抽象クラスは共通の機能を提供します


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

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

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