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