婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

直接選擇排序

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

選擇排序的主要優點與數據移動有關。如果某個元素位于正確的最終位置上,則它不會被移動。選擇排序每次交換一對元素,它們當中至少有一個將被移到其最終位置上,因此對n個元素的表進行排序總共進行至多n-1次交換。在所有的完全依靠交換去移動元素的排序方法中,選擇排序屬于非常好的一種。

原理

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

例子

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

舉例

對數組[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代碼實現

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;
}

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

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

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

巨人網絡通訊聲明:本文標題《PHP排序算法系列之直接選擇排序詳解》,本文關鍵詞  PHP,排序,算法,系列,之,直接,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP排序算法系列之直接選擇排序詳解》相關的同類信息!
  • 本頁收集關于PHP排序算法系列之直接選擇排序詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 武威市| 泗阳县| 通化市| 内丘县| 永康市| 牙克石市| 武功县| 柯坪县| 华坪县| 宾川县| 德阳市| 浦北县| 镇康县| 榕江县| 富民县| 交城县| 斗六市| 会泽县| 池州市| 南京市| 永宁县| 柯坪县| 沙雅县| 壤塘县| 嘉祥县| 永修县| 从化市| 德清县| 桂林市| 亚东县| 平原县| 萨迦县| 萍乡市| 刚察县| 清丰县| 云南省| 沂水县| 武山县| 阳山县| 开远市| 长宁县|