復制代碼 代碼如下:
 
<?php 
/** 
* 簡單選擇排序 simple selection sort 
* 
* 原理: 一次選定數組中的每一個數,記下當前位置并假設它是從當前位置開始后面數中的最小數min=i,從這個數的下一個數開始掃描直到最后一個數,并記錄下最小數的位置min,掃描結束后如果min不等于i,說明假設錯誤,則交換min與i位置上數。 
*/ 
function sort_simple_selection($list) 
{ 
$len = count($list); 
if(empty($len)) return $list; 
for($i = 0;$i < $len; $i++) 
{ 
$min = $i; 
for($j = $i + 1; $j < $len; $j++) 
{ 
//if($list[$j] > $list[$min]) // 從大到小 
if($list[$j] < $list[$min]) // 從小到大 
{ 
$min = $j; 
} 
echo implode(',',$list)."#pos=".($min + 1)." min=".$list[$min]."<br/>"; 
} 
if($min != $i) 
{ 
$temp = $list[$i]; 
$list[$i] = $list[$min]; 
$list[$min] = $temp; 
} 
echo "-------------------------<br/>"; 
} 
} 
$list = array(4,3,2,1,5,7,3,7); 
$list = sort_simple_selection($list); 
新聞熱點
疑難解答