插入排序算法的原理如下:
1、在第一轮里,暂时讲索引1的值抽出,并保存至临时变量中。
2、接着是平移阶段,我们会拿空隙左侧的每一个值域临时变量的值进行比较。
3、如果该值大于临时变量值,则将该值右移,否则把临时变量值插入当前位置。
4、重复步骤1~3,直到数组完成排序。
插入排序算法流程图:
-
插入排序时间复杂度:
插入排序代码实现:
/**
* 插入排序
* @param array $arr
* @return array
*/
function insertionSort(array $arr) {
for($i = 1, $count = count($arr); $i < $count; $i++){
$position = $i;
$temp_value = $arr[$i];
while ($position > 0 && $arr[$position - 1] > $temp_value) {
$arr[$position] = $arr[$position - 1];
$position--;
}
$arr[$position] = $temp_value;
}
return $arr;
}
//example:
$arr = [4,2,7,1,3];
print_r(insertionSort($arr));
//output:
Array
(
[0] => 1
[1] => 2
[2] => 3
[3] => 4
[4] => 7
)