《PHP編程:PHP簡單選擇排序算法實例》要點:
本文介紹了PHP編程:PHP簡單選擇排序算法實例,希望對您有用。如果有疑問,可以聯系我們。
簡單的選擇排序算法:通過n-i次關鍵字間的比擬,從n-i+1個記錄中選出關鍵字最小的記錄,并和第i(1<=i<=n)個記錄交換PHP實戰
代碼如下:
<?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),但選擇排序的性能還是略優于冒泡排序的.PHP實戰
《PHP編程:PHP簡單選擇排序算法實例》是否對您有啟發,歡迎查看更多與《PHP編程:PHP簡單選擇排序算法實例》相關教程,學精學透。維易PHP學院為您提供精彩教程。
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/12520.html