PHP でクイック ソートを再帰的に実装する方法の例
この記事では主に、PHP でクイック ソートを再帰的に実装する方法を紹介します。クイック ソートの原理を簡単に説明し、再帰アルゴリズムを使用してサンプルの形でクイック ソートを実装するための PHP の関連操作スキルを分析します。以下を参照してください。
この記事の例では、PHP でクイック ソートを再帰的に実装する方法について説明します。参考までに皆さんと共有してください。詳細は次のとおりです。
まず、クイック ソートの原理を理解する必要があります。:現在の配列内の要素を検索します (通常は選択します)最初の要素), 標準として、2 つの空の配列を作成し、配列要素全体を走査します。走査された要素が現在の要素より小さい場合は、左側の配列に配置され、それ以外の場合は、右側の配列に配置されます。 、そして新しい配列に対して同じことを行います。
これが再帰の原則と一致していることを見つけるのは難しくないので、再帰を使用して実装できます。
再帰を使用するには、再帰ポイントと再帰出口を見つける必要があります:
再帰ポイント: If の要素配列が 1 より大きい場合は、再度分解する必要があるため、再帰ポイントは、新しく構築された配列要素の数が 1 より大きいことです。
再帰終了:新しい配列を処理する必要がなくなるのはいつですか?並べ替えも必要なくなりますか?配列要素の数が 1 になると、これで終了です。
原理を理解したら、コードの実装を見てみましょう~
<?php //快速排序 //待排序数组 $arr=array(6,3,8,6,4,2,9,5,1); //函数实现快速排序 function quick_sort($arr) { //判断参数是否是一个数组 if(!is_array($arr)) return false; //递归出口:数组长度为1,直接返回数组 $length=count($arr); if($length<=1) return $arr; //数组元素有多个,则定义两个空数组 $left=$right=array(); //使用for循环进行遍历,把第一个元素当做比较的对象 for($i=1;$i<$length;$i++) { //判断当前元素的大小 if($arr[$i]<$arr[0]){ $left[]=$arr[$i]; }else{ $right[]=$arr[$i]; } } //递归调用 $left=quick_sort($left); $right=quick_sort($right); //将所有的结果合并 return array_merge($left,array($arr[0]),$right); } //调用 echo "<pre class="brush:php;toolbar:false">"; print_r(quick_sort($arr));
実行結果:
Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [5] => 6 [6] => 6 [7] => 8 [8] => 9 )
PS: 参考までに、並べ替えに関する別のデモンストレーション ツールをお勧めします:
##オンライン アニメーション デモの挿入/選択/バブル/マージ/ヒル/クイック ソート アルゴリズム プロセス ツール:
#http://tools.jb51.net/aideddesign/paixu_ys
興味があるかもしれない記事:
PHP で git デプロイメントを実装する方法に関する詳細なチュートリアルPHP 実装の二分法 検索アルゴリズム分析例と説明PHP に実装された半探索アルゴリズムの例説明以上が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.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます
