php數(shù)據(jù)結(jié)構(gòu) 算法(PHP描述) 簡(jiǎn)單選擇排序 simple selection sort
更新時(shí)間:2011年08月09日 12:09:51 作者:
一次選定數(shù)組中的每一個(gè)數(shù),記下當(dāng)前位置并假設(shè)它是從當(dāng)前位置開(kāi)始后面數(shù)中的最小數(shù)min=i,從這個(gè)數(shù)的下一個(gè)數(shù)開(kāi)始掃描直到最后一個(gè)數(shù),并記錄下最小數(shù)的位置min,掃描結(jié)束后如果min不等于i,說(shuō)明假設(shè)錯(cuò)誤,則交換min與i位置上數(shù)。
復(fù)制代碼 代碼如下:
<?php
/**
* 簡(jiǎn)單選擇排序 simple selection sort
*
* 原理: 一次選定數(shù)組中的每一個(gè)數(shù),記下當(dāng)前位置并假設(shè)它是從當(dāng)前位置開(kāi)始后面數(shù)中的最小數(shù)min=i,從這個(gè)數(shù)的下一個(gè)數(shù)開(kāi)始掃描直到最后一個(gè)數(shù),并記錄下最小數(shù)的位置min,掃描結(jié)束后如果min不等于i,說(shuō)明假設(shè)錯(cuò)誤,則交換min與i位置上數(shù)。
*/
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);
您可能感興趣的文章:
- PHP簡(jiǎn)單選擇排序算法實(shí)例
- PHP簡(jiǎn)單選擇排序(Simple Selection Sort)算法學(xué)習(xí)
- 用php實(shí)現(xiàn)選擇排序的解決方法
- php選擇排序法實(shí)現(xiàn)數(shù)組排序?qū)嵗治?/a>
- PHP排序算法系列之直接選擇排序詳解
- PHP 快速排序算法詳解
- PHP 冒泡排序算法的實(shí)現(xiàn)代碼
- PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
- php實(shí)現(xiàn)的常見(jiàn)排序算法匯總
- 排序算法之PHP版快速排序、冒泡排序
- PHP排序算法之簡(jiǎn)單選擇排序(Simple Selection Sort)實(shí)例分析
相關(guān)文章
如何取得中文字符串中出現(xiàn)次數(shù)最多的子串
以下是對(duì)取得中文字符串中出現(xiàn)次數(shù)最多的子串的實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08PHP中require和include路徑問(wèn)題詳解
這篇文章主要介紹了PHP中require和include路徑問(wèn)題詳解,十分詳細(xì),需要的朋友可以參考下2014-12-12如何在thinkphp中使用windows計(jì)劃任務(wù)定時(shí)執(zhí)行php文件
這篇文章主要介紹了如何在thinkphp中使用windows計(jì)劃任務(wù)定時(shí)執(zhí)行php文件,對(duì)定時(shí)執(zhí)行感興趣的同學(xué),可以參考下2021-04-04利用curl抓取遠(yuǎn)程頁(yè)面內(nèi)容的示例代碼
利用curl抓取遠(yuǎn)程頁(yè)面內(nèi)容的一個(gè)小示例,需要的朋友可以過(guò)來(lái)參考下2013-07-07PHP 截取字符串函數(shù)整理(支持gb2312和utf-8)
常見(jiàn)的 PHP 截取字符串函數(shù)整理,支持gb2312和utf-8編碼,方法php開(kāi)發(fā)中需要用到截取字符串的問(wèn)題。2010-02-02處理(php-cgi.exe?-?FastCGI?進(jìn)程超過(guò)了配置的請(qǐng)求超時(shí)時(shí)限)的問(wèn)題
本篇文章是對(duì)解決(php-cgi.exe?-?FastCGI?進(jìn)程超過(guò)了配置的請(qǐng)求超時(shí)時(shí)限)的問(wèn)題進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07phpMyAdmin 鏈接表的附加功能尚未激活問(wèn)題的解決方法(已測(cè))
今天幫客戶(hù)配置phpmyadmin,一直有“鏈接表的附加功能尚未激活”的問(wèn)題,登陸phpmyadmin后,會(huì)在底部顯示“鏈接表的附加功能尚未激活。要查出原因,請(qǐng)點(diǎn)擊此處。”的提示。2012-03-03