php实现基数排序,该怎么解决
程序员文章站
2022-06-10 18:33:19
...
php实现基数排序
刚开始学算法,碰上基数排序,就用php试试实现一下,但是有地方自己搞不懂
红色字体的地方,为什么要有这个才能正确运算呢
希望有人能帮我看看这样写对不对,或者有谁能贴一个漂亮点的写法(php)来给我参考一下,
感激不尽
/*
*计数排序
*$a是存储某数位的数组
*$arr是待排序数组
*/
function countsort($a,$arr){
$b = array();
foreach($a as $value){
$b[$value]++;
}
for($i = 1; $i $b[$i] = $b[$i] + $b[$i-1];
}
$c = array();
for($i = count($a)- 1; $i >= 0; $i--){
$c[$b[$a[$i]]] = $arr[$i];
$b[$a[$i]] = $b[$a[$i]] - 1;
}
return $c;
}
/*
*获取数组中各数某一数位数值,并返回该数组
*$num,用来获取数位的数组
*$tail获取哪个数位
*/
function gettail($num, $tail){
for($i = 0; $i if($num[$i] if($num[$i] >= pow(10,$tail-1)){
$temp[$i]=floor($num[$i]/pow(10,$tail-1));
}else{
$temp[$i] = floor(0);
}
}else{
$temp[$i] = floor($num[$i]%pow(10,$tail) / pow(10,$tail-1));
$flag = true;
}
}
return $temp;
}
/*
*基数排序
*/
function basesort($arr){
//4代表待排序数组中最大数的数位
for($i = 1; $i $temp = gettail($arr,$i);
$arr = countsort($temp,$arr);
for($j = 1; $j $new[$j-1] = $arr[$j];
}
$arr = $new;
}
return $arr;
}
$arr = array(11,342,543,213,98,312,0,234,322,455,164,88,100,999,1000);
print_r(basesort($arr));
?>
------解决方案--------------------
刚开始学算法,碰上基数排序,就用php试试实现一下,但是有地方自己搞不懂
红色字体的地方,为什么要有这个才能正确运算呢
希望有人能帮我看看这样写对不对,或者有谁能贴一个漂亮点的写法(php)来给我参考一下,
感激不尽
/*
*计数排序
*$a是存储某数位的数组
*$arr是待排序数组
*/
function countsort($a,$arr){
$b = array();
foreach($a as $value){
$b[$value]++;
}
for($i = 1; $i $b[$i] = $b[$i] + $b[$i-1];
}
$c = array();
for($i = count($a)- 1; $i >= 0; $i--){
$c[$b[$a[$i]]] = $arr[$i];
$b[$a[$i]] = $b[$a[$i]] - 1;
}
return $c;
}
/*
*获取数组中各数某一数位数值,并返回该数组
*$num,用来获取数位的数组
*$tail获取哪个数位
*/
function gettail($num, $tail){
for($i = 0; $i if($num[$i] if($num[$i] >= pow(10,$tail-1)){
$temp[$i]=floor($num[$i]/pow(10,$tail-1));
}else{
$temp[$i] = floor(0);
}
}else{
$temp[$i] = floor($num[$i]%pow(10,$tail) / pow(10,$tail-1));
$flag = true;
}
}
return $temp;
}
/*
*基数排序
*/
function basesort($arr){
//4代表待排序数组中最大数的数位
for($i = 1; $i $temp = gettail($arr,$i);
$arr = countsort($temp,$arr);
for($j = 1; $j $new[$j-1] = $arr[$j];
}
$arr = $new;
}
return $arr;
}
$arr = array(11,342,543,213,98,312,0,234,322,455,164,88,100,999,1000);
print_r(basesort($arr));
?>
------解决方案--------------------
专题推荐
-
独孤九贱-php全栈开发教程
全栈 170W+
主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门
-
玉女心经-web前端开发教程
入门 80W+
主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门
-
天龙八部-实战开发教程
实战 120W+
主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习
上一篇: C++二进制小数、对异域的理解
下一篇: 如何判断两个对象是否完全相等
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论