php數據結構 算法(PHP描述) 簡單選擇排序 simple selection sort
更新時間:2011年08月09日 12:09:51 作者:
一次選定數組中的每一個數,記下當前位置并假設它是從當前位置開始后面數中的最小數min=i,從這個數的下一個數開始掃描直到最后一個數,并記錄下最小數的位置min,掃描結束后如果min不等于i,說明假設錯誤,則交換min與i位置上數。
復制代碼 代碼如下:
<?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);
相關文章
如何在thinkphp中使用windows計劃任務定時執(zhí)行php文件
這篇文章主要介紹了如何在thinkphp中使用windows計劃任務定時執(zhí)行php文件,對定時執(zhí)行感興趣的同學,可以參考下2021-04-04處理(php-cgi.exe?-?FastCGI?進程超過了配置的請求超時時限)的問題
本篇文章是對解決(php-cgi.exe?-?FastCGI?進程超過了配置的請求超時時限)的問題進行了詳細的分析介紹,需要的朋友參考下2013-07-07phpMyAdmin 鏈接表的附加功能尚未激活問題的解決方法(已測)
今天幫客戶配置phpmyadmin,一直有“鏈接表的附加功能尚未激活”的問題,登陸phpmyadmin后,會在底部顯示“鏈接表的附加功能尚未激活。要查出原因,請點擊此處?!钡奶崾尽?/div> 2012-03-03最新評論