ホームページ >バックエンド開発 >PHPチュートリアル >PHP配列バブルソートアルゴリズムのサンプルコード

PHP配列バブルソートアルゴリズムのサンプルコード

怪我咯
怪我咯オリジナル
2017-07-13 10:29:571391ブラウズ

バブルソート (バブルソート) は、コンピューターサイエンスの分野における比較的単純なソートアルゴリズムです。

ソート対象のシーケンスを繰り返し訪問し、一度に 2 つの要素を比較し、順序が間違っている場合はそれらを交換します。配列を訪問する作業は、それ以上の交換が必要なくなるまで繰り返されます。これは、配列がソートされたことを意味します。

このアルゴリズムの名前は、より大きな要素が交換を通じて配列の先頭にゆっくりと「浮く」という事実に由来しています

この記事では主に、php配列バブルソートアルゴリズムを紹介し、次の形式で分析します。簡単な例 PHP 配列バブル ソート アルゴリズムの実装原理と関連テクニックを学習しました。必要な友人はそれを参照できます、詳細は次のとおりです:

<?php
/*@冒泡排序算法
*/
$array=array(5,45,22,11,32,28,35,56,17,21,92);
$len=count($array);//计算数组长度
for($i=0;$i<$len-1;$i++){//需要比较$len-1轮,每一轮需要比较$len-1次
  for($j=0;$j<$len-1;$j++){//需要比较$len-1次,因为循环到最后一个数时,后面没有数可以比较了,所以循环到倒数第二个数正好
   $k=$j+1;//得到当前数的后一个数的下标,我们依次比较的是数组下标分别为0-1,1-2,3-4的数值对
   if($array[$j]>$array[$k]){//比较两数,如果前一个数比后一个大,则交换两个数的顺序
     $t=$array[$j];
     $array[$j]=$array[$k];
     $array[$k]=$t;
   }//第一次循环比较完之后,进行下一轮比较
  }
}
print_r($array);
/*理解冒泡排序的关键在于,它的比较结果是大数往后放,依次得出的是最大的数,第二大的数,第三大的数。。。依次类推*/
?>

以上がPHP配列バブルソートアルゴリズムのサンプルコードの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。