插入排序排序
//测试调用
public function aa(){
$ad = [12,5,644,64,6546,54,54,897,321,231,54,321,56];
$res = $this->InsertSort($ad);
return $res;
}
/**
*@func 插入排序
* @describe 算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。
* 插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,
* 但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。
* 在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。
*
* @author vio
**/
private function InsertSort(array $arr=[]){
$count = count($arr);
for($i=1;$i<$count;$i++){
$t = $arr[$i];
$j = $i-1;
while ($j>=0 && $arr[$j]>$t){
$arr[$j+1] = $arr[$j];
$j--;
}
if ($i!=$j+1){
$arr[$j+1] = $t;
}
}
return $arr;
}
本作品采用《CC 协议》,转载必须注明作者和本文链接