PHP算法----插入排序

本文介绍了三种插入排序的方法:基本插入排序、改进版插入排序及进一步优化的插入排序,并通过代码实现展示了每种方法的具体操作过程及其运行时间。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.插入排序

/**  
* 插入排序 
* 
* @access public 
* @param mixed $arr 随机数组
* @return array 排序完成的数组
*/
function insertionSort($arr){
	$time_start = msectime();
	for ($i=1; $i < count($arr) ; $i++) { 		
		for ($j=$i; $j > 0 ; $j--) { 
			if($arr[$j]<$arr[$j-1]){
				$temp = $arr[$j];
				$arr[$j] = $arr[$j-1];
				$arr[$j-1] = $temp;
			}
		}
		
	}
	$time_end = msectime();
	var_dump($time_end-$time_start);
	return $arr;
}

2.插入排序改进

function insertionSort($arr){
	$time_start = msectime();
	for ($i=1; $i < count($arr) ; $i++) { 		
		for ($j=$i; $j > 0 && $arr[$j]<$arr[$j-1]; $j--) { 
			$temp = $arr[$j];
			$arr[$j] = $arr[$j-1];
			$arr[$j-1] = $temp;
		}
		
	}
	$time_end = msectime();
	var_dump($time_end-$time_start);
	return $arr;
}

3.插入排序再改进

function insert_sort($arr){
	$time_start = msectime();
	for ($i=1; $i < count($arr) ; $i++) { 		
		$e = $arr[$i];
		for ($j=$i; $j > 0 && $arr[$j-1]>$e; $j--) { 
			$arr[$j] = $arr[$j-1];
		}
		$arr[$j] = $e;
	}
	$time_end = msectime();
	var_dump($time_end-$time_start);
	return $arr;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值