计数排序php实现,PHP如何实现计数排序的代码

这篇文章给大家介绍的内容是关于PHP如何实现计数排序的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。/**

* 计数排序: 桶排序的一种

*/

$arr = [5,69,4,32,14,8,74,95,23,56,41,5,31,63];

// include 'data.php';

$length = count($arr);

$maxValue = $arr[0];

// 找出数组中的最大值

for ($i=1; $i < $length; $i++) {

if ($arr[$i] > $maxValue) {

$maxValue = $arr[$i];

}

}

/**

* 定长数组, 键会自动排序, PHP数组是hash表的实现,

* 如果这里用普通的数组, 键不会自动排序, 不存在的键也不会自动填充null

*/

$frequency = new SplFixedArray($maxValue + 1);

/**

* 统计arr中, 值出现的频次

*/

for ($i=0; $i < $length; $i++) {

if(empty($frequency[$arr[$i]]))

$frequency[$arr[$i]] = 0;

$frequency[$arr[$i]] += 1;

}

// 清空$arr

$arr = [];

// 遍历frequency, 如果其元素有值, 那么将键push到arr中

for ($i=0; $i < count($frequency); $i++) {

if (!empty($frequency[$i])) {

for ($j=0; $j < $frequency[$i]; $j++) {

$arr[] = $i;

}

}

}

print_r($arr);

相关文章推荐:

php中echo()函数的用法(附代码)

Nginx如何来配置隐藏入口文件index.php(代码)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值