PHP 冒泡排序

冒泡排序是公认的排序算法中最慢的一种 , 其原理为两两比较将大的数据逐个交换 , 其过程类似于冒泡因此叫冒泡排序 .

PHP 代码 :

// 交换
function swap(& $a, & $b) {
  $temp = $a;
  $a = $b;
  $b = $temp;
}

function bubbleSort($a) {
  $l = count($a);
  for($i=0; $i<$l; $i++) {
    $flag = false;
    for($j=$l-1; $j>$i; $j--) {
      if($a[$j] < $a[$j-1]) {
        swap($a[$j], $a[$j-1]);
        $flag = true;
      }
    }
    if(!$flag) break;
  }
  return $a;
}


用法 :

echo(implode(",", bubbleSort($a)));// $a 是无序数组 , 例如 $a = range(1,100);shuffle($a);


嘿嘿 , 如果有更好的思想 , 请评论哈 .

你可能感兴趣的:(数据结构,PHP,算法,冒泡排序)