快速、冒泡排序算法(PHP版)

1.冒泡排序算法改进:

方法一:

 1 function bubbleSort($arr){//$arr(1...n)是待排序的文件,采用自下向上扫描,对$arr做冒泡排序
 2     $bFlag = true; //交换标志
 3     for($i=0; $i<count($arr); $i++){ //最多做n-1趟排序
 4         $bFlag = false; //本趟排序开始前,交换标志应为假
 5         for($j = count($arr)-2; $j >= $i; $j--){ //对当前无序区$arr[i..n]自下向上扫描
 6             if( $arr[$j+1] < $arr[$j] ){//交换记录
 7                 $temp = $arr[$j+1]; //$temp不是哨兵,仅做暂存单元
 8                 $arr[$j+1] = $arr[$j];
 9                 $arr[$j] = $temp;
10                 $bFlag = true; //发生了交换,故将交换标志置为真
11             }
12         }
13         if(!$bFlag){ //本趟排序未发生交换,提前终止算法
14              break;
15         }
16     } //endfor(外循环)
17     print_r($arr);
18 } //BubbleSort

方法二:

 1 function bubbleSort($arr){
 2     $bSort = false;
 3     for ($i=0; $i<count($arr) && !$bSort; $i++) {  
 4         $bSort = true;
 5         for ($j = 0; $j<count($arr) - $i - 1; $j++) {  
 6             if ($arr[$j] > $arr[$j+1]) {  
 7                 $bSort = false;
 8                  // 不使用第三个变量  
 9                 $arr[$j] = $arr[$j] + $arr[$j+1];  
10                 $arr[$j+1] = $arr[$j] - $arr[$j+1];  
11                 $arr[$j] = $arr[$j] - $arr[$j+1];  
12             }  
13         }  
14     }
15 }

 2.快速排序算法:

 1 function quick_sort($array) {
 2     if (count( $array ) <= 1) return $array;
 3     $key = $array [0];
 4     $left_arr = array ();
 5     $right_arr = array ();
 6     
 7     for($i = 1; $i < count( $array ); $i ++) {
 8         if ($array [$i] <= $key)
 9             $left_arr [] = $array [$i];
10         else
11             $right_arr [] = $array [$i];
12     }
13     $left_arr = quick_sort ( $left_arr );
14     $right_arr = quick_sort ( $right_arr );
15     return array_merge ( $left_arr, array ($key ), $right_arr );
16 }

 

posted on 2013-07-29 17:11  宁静*勤奋  阅读(250)  评论(0编辑  收藏  举报