冒泡排序

冒泡排序:

1基本算法思想:

l依次比較相鄰的兩個元素,消除逆序(逆序是數學上的概念,是成對出現的,好比50,30就是一對逆序,所謂的消除逆序,就是大的放後面,小的放前面)
l這樣,一輪比較下來,最大的那個數一對是在最後面!
l而後,再繼續新的一輪的比較,注意,剛纔一輪後的最大值再也不參與比較,這樣,這一輪參與比較的數值就比上一輪少一個,如此反覆,直到最後只剩下兩個數值比較爲止!

因此:應該是一個雙重循環,外層控制輪數,內層控制每輪比較的次數!php

二、示例代碼:

<?php
echo '<pre>';
function maopao($arr){算法

for($i=1,$len=count($arr);$i<$len;$i++){
for($k=0;$k<$len-$i;$k++){
if($arr[$k]>$arr[$k+1]){
$tem = $arr[$k];
$arr[$k] = $arr[$k+1];
$arr[$k+1] = $tem;

     }
    }
}
return $arr;
}
$arr1 = array(78,90,67,45,23,12,34,54,32);
var_dump(maopao($arr1));spa

相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息