php面试必备,如何实现冒泡排序?
冒泡排序在面试当中经常遇到,在一组数字当中,两两相比较,数字小的就向前调换顺序,依次作比较到最后一个数字,由于像气泡一样,越小的越在最前边,故称为冒泡排序。
下面以实际代码来看冒泡排序是怎么实现的。
// 定义一个随机的数组
$a = array(23,15,43,25,54,2,6,82,11,5,21,32,65);
// 第一层可以理解为从数组中键为0开始循环到最后一个
for ($i = 0; $i < count($a) ; $i++) {//// 第二层为从$i+1的地方循环到数组最后
for ($j = $i+1; $j < count($a); $j++) {// 比较数组中两个相邻值的大小
if ($a[$i] > $a[$j]) {
$tem = $a[$i]; // 这里临时变量,存贮$i的值
$a[$i] = $a[$j]; // 第一次更换位置
$a[$j] = $tem; // 完成位置互换
}
}
}