ホームページ > バックエンド開発 > PHPチュートリアル > 配列ソートを実装するための PHP 挿入ソートメソッド example_PHP チュートリアル

配列ソートを実装するための PHP 挿入ソートメソッド example_PHP チュートリアル

WBOY
リリース: 2016-07-13 10:04:10
オリジナル
961 人が閲覧しました

配列ソートを実装するためのPHP挿入ソートメソッドの例

この記事では、主に配列ソートを実装するためのPHP挿入ソートメソッドを紹介します。この例では、挿入ソートメソッドの原理と具体的な実装スキルを分析します。必要な場合は参考にしてください

この記事の例では、PHP の挿入ソート方法を使用して配列ソートを実装する方法を説明します。皆さんの参考に共有してください。具体的な分析は次のとおりです:

挿入ソート方法の基本的な考え方: 同じ例を使用して、引き続き $arr = array(2,6,3,9) を使用して、大きいものから小さいものへソートします。

実装原理: (実際に作成せずに) 順序付けられた配列 $arr = array(2) があると仮定します。$arr[1]=6 を使用してそれと比較し、6>2 の場合は $arr[0] を使用します。次に、$arr[1] の位置に移動し、$arr[0] の位置に 6 が挿入されます。次に、$arr[2]=3 と $arr[1]=2, 3>2 が比較され、$arr[1]=2 は $arr[2] の位置、つまり元の $arr[3] に移動し続けます。 ]=3 $arr[1] の位置に挿入し、引き続き終了位置に 9 を挿入します。最終結果は (9,6,3,2) です。並べ替えは、count($arr)-1 の大きなループの後にも実行できます。

コードパターン分析:

最初の大きなサイクル: $[1] と $[0] の比率;
2 番目の大きなサイクル: $[2] 対 $[1]、$[1] 対 $[0]; 3 番目の大きなサイクル: $[3] 対 $[2]、$[2] 対 $[1]、$[1] 対 $[0];
PHP コードは使いやすさを考慮して関数のカプセル化を使用しています

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

関数 insertSort(&$arr){

for($i=1;$i

//$insertVal は挿入される番号です

for($j=$i;$j>0;$j--){

if($arr[$j]>$arr[$j-1]){

$insertVal = $arr[$j];

$arr[$j] = $arr[$j-1];

$arr[$j-1] = $insertVal;

}

}

}

}

$myarr = 配列(2,6,3,9);

insertSort($myarr);

エコー「

」;
            

print_r($myarr);

?>

コード実装分析:

最初の大きなサイクル:

$i=1 配列(2,6,3,9)

$j=1 6 と 2 の比率を実行します: $arr[1]=2;$arr[0]=6, get (6,2,3,9)


2 番目の大きなサイクル:

$i=2 配列(6,2,3,9)

$j=2 は 3 と 2 の比率を実行します。$arr[2]=2、$arr[1]=3 となり、(6,3,2,9) が得られます

$j--,$j=1 $arr[1] と $arr[0] の比率を実行: 条件が満たされません

3 番目のサイクル:

$i=3 配列(6,3,2,9)

$j=3 は 9 と 2 の比率を実行します。$arr[3]=2、$arr[2]=9 となり、(6,3,9,2) が得られます

$j--,$j=2 9と3の比率を実行すると、$arr[2]=3, $arr[1]=9となり、(6,9,3,2)が得られます
$j--,$j=1 は 9 と 6 の比率を実行します。$arr[1]=5、$arr[0]=9 となり、(9,6,3,2) が得られます

この記事で説明した内容が皆様の PHP プログラミング設計に役立つことを願っています。

http://www.bkjia.com/PHPjc/966909.html

tru​​ehttp://www.bkjia.com/PHPjc/966909.html技術記事配列ソートを実現するための PHP 挿入ソートメソッドの例 この記事では主に、配列ソートを実装するための PHP 挿入ソートメソッドを紹介します。この例では、挿入ソートメソッドの原理と具体的な実装スキルを分析します。
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート