排序算法之插入排序

插入排序算法的原理如下

1、在第一轮里,暂时讲索引1的值抽出,并保存至临时变量中。

2、接着是平移阶段,我们会拿空隙左侧的每一个值域临时变量的值进行比较。

3、如果该值大于临时变量值,则将该值右移,否则把临时变量值插入当前位置。

4、重复步骤1~3,直到数组完成排序。

插入排序算法流程图:

-

插入排序时间复杂度

O(N^{2})

插入排序代码实现:

/**
 * 插入排序
 * @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
)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值