php数组冒泡排序算法实例

本文实例讲述了php数组冒泡排序算法。分享给大家供大家参考,具体如下:

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