《大話數據結構》中這樣介紹冒泡排序的基本思想:兩兩比較相鄰元素的關鍵字,如果反序則交換,直到沒有反序的記錄為止。也就是相鄰元素之間兩兩比較,如果前一個值大於後一個(或者前一個值小於後一個),則交換順序,所以這樣的話,最終的結果是從小到大(或者從大到小)的排序。
當然php有非常強大的排序函數,比如sort,asort等,所以也在運用php的時候也用不著自己寫排序函數,這裡只是用php實現下冒泡排序的思想。
1 <?php 2 include_once './header.php'; 3 4 $bub = array(9,5,8,3,4,6,1,2,7,); 5 $sortarr = $asortarr = $bub; 6 7 //冒泡排序 8 $flag = true; 9 for($i=0; $i<count($bub)-1 && $flag; $i++){ //當flag為false時,已經排序完成,後面不再循環 10 11 $flag = false; 12 for($j=count($bub)-2; $j>=$i; $j--){ 13 14 if($bub[$j]>$bub[$j+1]){ //前面的數大於後面的數,交換位置 15 16 $temp = $bub[$j]; 17 $bub[$j] = $bub[$j+1]; 18 $bub[$j+1] = $temp; 19 $flag = true; 20 } 21 } 22 } 23 //對數組單元從低到高重新排序 24 sort($sortarr); 25 //對數組重新排序並保持索引關系 26 asort($asortarr); 27 28 echo '冒泡:'; 29 echo '<pre>'; 30 var_dump($bub); 31 32 echo 'sort:'; 33 echo '<pre>'; 34 var_dump($sortarr); 35 36 echo 'asort:'; 37 echo '<pre>'; 38 var_dump($asortarr); 39 ?>
代碼的輸出結果: