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

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

熱門標(biāo)簽:南寧高頻外呼回?fù)芟到y(tǒng)哪家好 電話機(jī)器人危險(xiǎn)嗎 長(zhǎng)沙crm外呼系統(tǒng)業(yè)務(wù) 400電話申請(qǐng)方法收費(fèi) 專業(yè)電話機(jī)器人批發(fā)商 江蘇外呼電銷機(jī)器人報(bào)價(jià) 400電話辦理福州市 深圳外呼系統(tǒng)收費(fèi) 離石地圖標(biāo)注

直接選擇排序

直接選擇排序(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次,得到一個(gè)按排序碼從小到大排列的有序序列·

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

原理

首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再?gòu)氖S辔磁判蛟刂欣^續(xù)尋找最小(大)元素,然后放到已排序序列的末尾。以此類推,直到所有元素均排序完畢。

例子

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

舉例

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

首先取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]

重復(fù)上述步驟

PHP代碼實(shí)現(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;
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

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

標(biāo)簽:濱州 南京 太原 曲靖 興安盟 南昌 株洲 白酒營(yíng)銷

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP排序算法系列之直接選擇排序詳解》,本文關(guān)鍵詞  PHP,排序,算法,系列,之,直接,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP排序算法系列之直接選擇排序詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP排序算法系列之直接選擇排序詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章