<?php function insert_sort($arr) { //插入排序法 $len=count($arr); for($i=1; $i<$len; $i++) { //得到当前须要比较的元素值。 $tmp = $arr[$i]; //内层循环控制 比较 并 插入 for($j=$i-1; $j>=0; $j--) { //$arr[$i];//须要插入的元素; $arr[$j];//须要比较的元素 if($tmp < $arr[$j]) { //发现插入的元素要小,交换位置 //将后边的元素与前面的元素互换 $arr[$j+1] = $arr[$j]; //将前面的数设置为 当前须要交换的数 $arr[$j] = $tmp; } else { //若是碰到不须要移动的元素 //因为是已经排序好是数组,则前面的就不须要再次比较了。 break; } } } //将这个元素 插入到已经排序好的序列内。 //返回 return $arr; } $arr=array(54,1,43,62,21,66,32,78,36,76,0,17,39,-1); echo '<pre>'; print_r(insert_sort($arr)); ?>