国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

PHP簡單選擇排序算法實例

2024-05-04 23:30:40
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了PHP簡單選擇排序算法實例,本文直接給出實現代碼,并以類的方式實現,需要的朋友可以參考下
 

簡單的選擇排序算法:通過n-i次關鍵字間的比較,從n-i+1個記錄中選出關鍵字最小的記錄,并和第i(1<=i<=n)個記錄交換

 

復制代碼代碼如下:

<?php
    class Sort{ 
        /**
         * 簡單的選擇排序
         * 
         * @param unknown_type $arr
         */
        public function selectSort(&$arr) { 
            $len=count($arr);
            for ($i=0;$i<$len;$i++) {
                $min=$i;
                for ($j=$i+1;$j<=$len-1;$j++) {
                    if ($arr[$min]>$arr[$j]) {//如果找到比$arr[$min]較小的值,則將該下標賦給$min
                        $min=$j;
                    }
                }
                if ($min!=$i){//若$min不等于$i,說明找到了最小值,則交換
                    $this->swap($arr[$i],$arr[$min]);
                }
            }
        }
        /**
         * 將$a和$b兩個值進行位置交換
         */
        public function swap(&$a,&$b) {
            $temp=$a;
            $a=$b;
            $b=$temp;
        }
    }
    $arr=array(4,6,1,2,9,8,7,3,5);
    $test=new Sort(); 
    $test->selectSort($arr);//簡單的選擇排序
//    var_dump($arr);
?>

 

簡單選擇排序的特點:交換移動數據次數相當少,從而節約了相應的時間
簡單選擇排序的時間復雜度分析:
無論最好最差的情況,其比較次數都是一樣多,第i趟排序需要進行n-i次關鍵字的比較,此時需要比較n(n-1)/2次。所以最終的時間復雜度是O(n^2)
盡管與冒泡排序同為O(n^2),但選擇排序的性能還是略優于冒泡排序的。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 隆昌县| 临湘市| 铜梁县| 黎平县| 孟连| 赫章县| 朔州市| 通州区| 保靖县| 潞西市| 错那县| 咸丰县| 应用必备| 策勒县| 嘉黎县| 张北县| 新和县| 安陆市| 深州市| 勐海县| 永修县| 大厂| 民权县| 永登县| 深泽县| 嘉禾县| 乌鲁木齐县| 墨玉县| 乐平市| 海兴县| 南乐县| 于田县| 苏尼特左旗| 武鸣县| 通山县| 泗阳县| 当雄县| 奈曼旗| 镇平县| 邛崃市| 怀来县|