基数排序是一种排序算法,该算法通过按共享相同有效位和值的单个数字对键进行分组,对带有整数键的数据进行排序。
我们需要编写一个JavaScript函数,该函数以文字数组作为唯一参数。该函数应使用基数排序算法以升序或降序对数组进行排序。
以下是代码-
输出结果const arr = [45, 2, 56, 2, 5, 6, 34, 1, 56, 89, 33];
const radixSort = (arr = []) => {
const base = 10;
let divider = 1;
let maxVal = Number.NEGATIVE_INFINITY;
while (divider === 1 || divider <= maxVal) {
const buckets = [...Array(10)].map(() => []);
for (let val of arr) {
buckets[Math.floor((val / divider) % base)].push(val);
maxVal = val > maxVal ? val : maxVal;
}
arr = [].concat(...buckets);
divider *= base;
};
return arr;
};
console.log(radixSort(arr));
以下是控制台上的输出-
[
1, 2, 2, 5, 6,
33, 34, 45, 56, 56,
89
]