桶式排序

<?php

	/**
	* 桶式排序
	*
	* 思路: 造做一个空桶, 然后把有值的数在空桶中做一个标记,再便利这个桶就得出了排序好的数
	* @param $arr 要排序的数组
	* @return array 排序好的数组
	*/
	function Bucket($arr){
		// 放入已排序好的数
		$arrs = array();

		// 计算出最大值,最小值
		$max = max($arr);
		$min = min($arr);

		// 造一个空桶
		$bucket = array_fill($min,$max-1,0);

		// 便利做标记
		foreach($arr as $v){
			$bucket[$v]++;
		}

		// 把做好标记的数取出,得到就是已经排序好的数
		foreach($bucket as $k => $v){
			for($i=0; $i<$v; ++$i){
				$arrs[] = $k;
			}
		}
		return $arrs;
	}
	echo '<pre>';
	$arr = array(12,6,18,2,9,14);
	print_r(Bucket($arr));

?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值