先用乙個基準元素,將陣列分成兩部分,一部分比基準元素小,一部分大於等於基準元素。此時基準元素在其排好序後的正確位置,然後再用同樣的方法遞迴地排序劃分的兩部分。
function quicksort($arr)
//選擇第乙個元素作為基準
$base_num = $arr[0];
//遍歷除了標尺外的所有元素,按照大小關係放入兩個陣列內
//初始化兩個陣列
$left_array = array(); //小於基準的
$right_array = array(); //大於基準的
for($i=1; $i<$length; $i++) else
}//再分別對左邊和右邊的陣列進行相同的排序處理方式遞迴呼叫這個函式
$left_array = quicksort($left_array);
$right_array = quicksort($right_array);
//合併
return array_merge($left_array, array($base_num), $right_array);
}假設前面的數已經是排好順序的,把後面的數依次插到前面的有序數中。
function insertsort($arr) else }}
return $arr;
}依次從後面選出最小(最大)的乙個數與前面的數交換位置。
function selectsort($arr)
}//已經確定了當前的最小值的位置,儲存到$p中。如果發現最小值的位置與當前假設的位置$i不同,則位置互換即可。
if($p != $i)
}//返回最終結果
return $arr;
}從前往後對相鄰的兩個數依次進行比較,每當它們的排序與排序要求相反時,就將它們互換。
function bubblesort($arr)
}} return $arr;
}
php 快速排序演算法,PHP 快速排序演算法
概念 快速排序演算法是對冒泡演算法的乙個優化。他的思想是先對陣列進行分割,把大的元素數值放到乙個臨時陣列裡,把小的元素數值放到另乙個臨時陣列裡 這個分割的點可以是陣列中的任意乙個元素值,一般用第乙個元素,即 array 0 然後繼續把這兩個臨時陣列重複上面拆分,最後把小的陣列元素和大的陣列元素合併起...
PHP排序演算法
對於php中對陣列的元素進行排序,這個是很經常用到的,之前的專案中也有,而且對於幾種排序我們都是用的是asort arsort 等php原生函式,沒有自己去實現,所以就對一下的幾個函式進行總結,這個會不斷的進行補充,自己也可以好好的複習和總結。直接上 吧!插入排序 一維陣列 每次將乙個待排序的資料元...
PHP排序演算法
氣泡排序 function bubblesort arr return arr 交換法排序 function exchangesort arr return arr 選擇法排序 function selectsort arr 把當前值放到算好的位置 arr ipos arr i 把當前值換成算好的值...