//选择排序
//选择排序 思路:每次选择一个相应的元素,然后将其放到指定的位置
protected function selectSort($arr)
{
// 实现思路
// 双重循环完成,外层控制轮数,假设当前的最小值,内层控制比较次数
// 获取长度
$length = count($arr);
for ($i = 0; $i < $length - 1; $i++) {
// 假设最小值的位置
$p = $i;
// 使用假设的最小值和其他值比较,找到当前的最小值
for ($j = $i + 1; $j < $length; $j++) {
// $arr[$p] 是已知的当前最小值
// 判断当前循环值和已知最小值的比较,当发现更小的值时记录下键,并进行下一次比较
if ($arr[$p] > $arr[$j]) {
$p = $j; // 比假设的值更小
}
}
// 通过内部for循环找到了当前最小值的key,并保存在$p中
// 判断 当前$p 中的键和假设的最小值的键不一致,将其互换
if ($p != $i) {
$tmp = $arr[$p];
$arr[$p] = $arr[$i];
$arr[$i] = $tmp;
}
}
// 返回最终结果
return $arr;
}
网友评论