濮阳杆衣贸易有限公司

主頁 > 知識庫 > PHP排序算法系列之直接選擇排序詳解

PHP排序算法系列之直接選擇排序詳解

熱門標簽:南寧高頻外呼回撥系統(tǒng)哪家好 電話機器人危險嗎 長沙crm外呼系統(tǒng)業(yè)務 400電話申請方法收費 專業(yè)電話機器人批發(fā)商 江蘇外呼電銷機器人報價 400電話辦理福州市 深圳外呼系統(tǒng)收費 離石地圖標注

直接選擇排序

直接選擇排序(Straight Select Sorting) 的基本思想是:第一次從R[0]~R[n-1]中選取最小值,與R[0]交換,第二次從R[1]~R[n-1]中選取最小值,與R[1]交換,….,第i次從R[i-1]~R[n-1]中選取最小值,與R[i-1]交換,…..,第n-1次從R[n-2]~R[n-1]中選取最小值,與R[n-2]交換,總共通過n-1次,得到一個按排序碼從小到大排列的有序序列·

選擇排序的主要優(yōu)點與數(shù)據(jù)移動有關。如果某個元素位于正確的最終位置上,則它不會被移動。選擇排序每次交換一對元素,它們當中至少有一個將被移到其最終位置上,因此對n個元素的表進行排序總共進行至多n-1次交換。在所有的完全依靠交換去移動元素的排序方法中,選擇排序?qū)儆诜浅:玫囊环N。

原理

首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再從剩余未排序元素中繼續(xù)尋找最小(大)元素,然后放到已排序序列的末尾。以此類推,直到所有元素均排序完畢。

例子

設數(shù)組為a[0…n-1]。
1.初始時,數(shù)組全為無序區(qū)為a[0..n-1]。令i=0
2.在無序區(qū)a[i…n-1]中選取一個最小的元素,將其與a[i]交換。交換之后a[0…i]就形成了一個有序區(qū)。
3.i++并重復第二步直到i==n-1。排序完成。

舉例

對數(shù)組[53,89,12,98,25,37,92,5]進行排序

首先取i=0;a[i]為最小值,將后面的值與a[i]比較,若比a[i]小,則與a[i]交換位置,$i++

[5,89,53,98,25,37,92,12]

首先取i=1;a[i]為最小值,將后面的值與a[i]比較,若比a[i]小,則與a[i]交換位置,$i++

[5,12,89,98,53,37,92,25]

重復上述步驟

PHP代碼實現(xiàn)

function select_sort($arr){
  $length=count($arr);
  for ($i=0; $i $length-1 ; $i++) {
    for ($j=$i+1,$min=$i; $j $length ; $j++) {
      if ($arr[$min]>$arr[$j]) {
        $min=$j;
      }
    }
    $temp=$arr[$i];
    $arr[$i]=$arr[$min];
    $arr[$min]=$temp;
  }
  return $arr;
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • php數(shù)據(jù)結構 算法(PHP描述) 簡單選擇排序 simple selection sort
  • PHP簡單選擇排序算法實例
  • PHP簡單選擇排序(Simple Selection Sort)算法學習
  • 用php實現(xiàn)選擇排序的解決方法
  • php選擇排序法實現(xiàn)數(shù)組排序?qū)嵗治?/li>
  • PHP 快速排序算法詳解
  • PHP 冒泡排序算法的實現(xiàn)代碼
  • PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
  • php實現(xiàn)的常見排序算法匯總
  • 排序算法之PHP版快速排序、冒泡排序
  • PHP排序算法之簡單選擇排序(Simple Selection Sort)實例分析

標簽:濱州 南京 太原 曲靖 興安盟 南昌 株洲 白酒營銷

巨人網(wǎng)絡通訊聲明:本文標題《PHP排序算法系列之直接選擇排序詳解》,本文關鍵詞  PHP,排序,算法,系列,之,直接,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP排序算法系列之直接選擇排序詳解》相關的同類信息!
  • 本頁收集關于PHP排序算法系列之直接選擇排序詳解的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    惠安县| 大姚县| 馆陶县| 清水河县| 长泰县| 丽江市| 玛曲县| 开江县| 仙桃市| 苏州市| 大同市| 云安县| 天气| 怀宁县| 西安市| 兴隆县| 会同县| 新营市| 四子王旗| 万州区| 澳门| 宣汉县| 巍山| 永吉县| 义乌市| 岳阳县| 廉江市| 柘城县| 万安县| 霍林郭勒市| 峨眉山市| 枝江市| 营口市| 开江县| 上饶县| 繁峙县| 桂阳县| 青龙| 吉林市| 高要市| 陇南市|