排序算法之选择排序

选择排序算法的原理如下

1、从左到右检查数组的每个元素,找出值最小的那个值索引并记录下来。

2、将步骤1记录下的最小值索引与本次检查的起点索引交换(第1次起点0,第2次起点1,第n次起点n-1)。

3、重复步骤1和步骤2,直到数组排好序。

选择排序算法流程图:

选择排序时间复杂度

O(N^{2}/2) 忽略常数项即:O(N^{2})

选择排序代码实现:

/**
 * 选择排序
 * @param  array  $arr
 * @return array
 */
function selectionSort(array $arr) :array {
    $count = count($arr);
    for($i = 0; $i < $count; $i++){
        $lower_index = $i;
        for($j = $i + 1; $j < $count; $j++){
            if($arr[$j] < $arr[$lower_index]){
                $lower_index = $j;
            }
        }
        
        if($i != $lower_index){
            list($arr[$i], $arr[$lower_index]) = array($arr[$lower_index], $arr[$i]);
        }
    }
    
    return $arr;
}

//example:
$arr = [4,2,7,1,3];
print_r(selectionSort($arr));

//output:
Array
(
    [0] => 1
    [1] => 2
    [2] => 3
    [3] => 4
    [4] => 7
)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值