php算法之选择排序

PHP实现选择排序算法

目录

选择排序法

思路

示例

总结


选择排序法

思路

每次选择一个相应的元素,然后将其放到指定的位置
每次通过内循环,使假定的最小值与其他值得对比,得到最小值  
并通过内循环下的if条件选择进行位置交换


每层循环确定一个最小值
例:数组 10,3,7,2,9,11,1  假定$min_k=0 最小值下标 第一层
        3,10,7,2,9,11,1      $min_k=1
        3,10,7,2,9,11,1      $min_k=1
        2,10,7,3,9,11,1      $min_k=3
        2,10,7,3,9,11,1      $min_k=3
        2,10,7,3,9,11,1      $min_k=3
        1,10,7,3,9,11,2      $min_k=6
从中确定 $i=0 $p=6 而$i>$p
则让数组的两个键相互交换,确定该数组最小值
即 1,3,7,2,9,11,10
在进行二层循环,减少一个数的循环判断 即最小值
每次循环确定一个最小值,进行排序

最后循环完毕,排序完毕

示例

封装好的选择排序方法,代码如下:

header('content-type:text/html;charset=utf8 ');

function select_sort($arr) {
	for($i=0, $len=count($arr); $i<$len-1; $i++) {
		$p = $i;
		for($j=$i+1; $j<$len; $j++) {
			//$arr[$p] 是 当前已知的最小值
			if($arr[$p] > $arr[$j]) {
				$p = $j;
			}
		}
		if($p != $i) {
			$tmp = $arr[$p];
			$arr[$p] = $arr[$i];
			$arr[$i] = $tmp;
		}
	}
	return $arr;
}

$arr = array(50,2,45,12,46,47,23,40,15,60,39,67,80,34);

//调用排序方法
echo "<pre>";
print_r(select_sort($arr));

数组打印结果:

Array
(
    [0] => 2
    [1] => 12
    [2] => 15
    [3] => 23
    [4] => 34
    [5] => 39
    [6] => 40
    [7] => 45
    [8] => 46
    [9] => 47
    [10] => 50
    [11] => 60
    [12] => 67
    [13] => 80
)

总结

PHP实现选择排序算法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JSON_L

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值