You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

46 lines
1.2 KiB
PHP

<?php
function radix_sort($elements) {
// Array for 10 queues.
$queues = array(
array(), array(), array(), array(), array(), array(), array(), array(),
array(), array()
);
// Queues are allocated dynamically. In first iteration longest digits
// element also determined.
$longest = 0;
foreach ($elements as $el) {
if ($el > $longest) {
$longest = $el;
}
array_push($queues[$el % 10], $el);
}
// Queues are dequeued back into original elements.
$i = 0;
foreach ($queues as $key => $q) {
while (!empty($queues[$key])) {
$elements[$i++] = array_shift($queues[$key]);
}
}
// Remaining iterations are determined based on longest digits element.
$it = strlen($longest) - 1;
$d = 10;
while ($it--) {
foreach ($elements as $el) {
array_push($queues[floor($el/$d) % 10], $el);
}
$i = 0;
foreach ($queues as $key => $q) {
while (!empty($queues[$key])) {
$elements[$i++] = array_shift($queues[$key]);
}
}
$d *= 10;
}
}
// Example usage:
$a = array(170, 45, 75, 90, 802, 24, 2, 66);
print_r($a);
radix_sort($a);
print_r($a);
?>