算法2.6基数排序

基数排序

属于分配式排序,又称桶子法,通过键值的各个位上的值,将要排序的元素分配至某些桶中,达到排序的作用.

基数排序属于稳定性排序,是效率高的稳定性排序法

是桶排序的扩展,将整数按照位数进行切割,再按各个位数进行比较

是用空间换时间的经典算法

在使用8kw个数据进行测试时

需要8kw*11个数组 *4个字节 /1024k/1024m/1024g = 3.3G

不难看出基数排序对空间的要求非常高

排序思路

eg:{53,3,542,748,14,214}

第一轮:

1,取出每个元素的个位数

2,判断这个数应该放在对应的哪一个桶

3,按照桶的顺序依次放回原数组

//个位小的在放回去后会在前面

第二轮:

1,取出每个元素的十位数

2,判断这个数应该放在哪一个桶,如果没有十位则补零

3,按照桶顺序依次放回原数组

//十位小的在放回去后会在前面

...

//此时在依次放入桶中时,最高位相同的数,十位小的会被先放入

直到最高位放入桶中

此时再按最高位放入队列

记录每个桶中放置了多少数据

代码实现

定义一个二维数组,表示10个桶,每个桶为一个一维数组

定义一个10个元素的一维数组用以保存从0-9的桶中数量

按位循环遍历数组中每个元素直到遍历到最高位结束

java 复制代码
public void bucketsort(int[] arr) {
    int[][] arr1 = new int[10][arr.length];
    int max = arr[0];
    for (int i = 0; i < arr.length; i++) {
        max = Math.max(max, arr[i]);
    }
    for (int i = 0; i < Integer.toString(max).length(); i++) {
        int[] count = new int[10];
        for (int i1 = 0; i1 < arr.length; i1++) {
            int temp = arr[i1] / (int) (Math.pow(10, i)) % 10;
            arr1[temp][count[temp]] = arr[i1];
            count[temp]++;
        }
        int t = 0;
        for (int i1 = 0; i1 < 10; i1++) {
            for (int k = 0; k < count[i1]; k++) {
                arr[t] = arr1[i1][k];
                t++;
            }
        }
    }
}
总结

并不复杂的思路,典型的空间换时间算法

相关推荐
无缘之缘3 分钟前
蓝桥杯手把手教你备战(C/C++ B组)(最全面!最贴心!适合小白!)
c语言·c++·算法·蓝桥杯
Dfreedom.6 分钟前
【实战篇】神经网络在回归任务中的应用
人工智能·神经网络·算法·机器学习·回归
嘿黑嘿呦7 分钟前
17届蓝桥杯考前准备
算法·职场和发展·蓝桥杯
Q741_1478 分钟前
每日一题 3740. 三个相等元素之间的最小距离 I 3741. 三个相等元素之间的最小距离 II 模拟 哈希表 C++ 题解
c++·算法·leetcode·模拟·数组·哈希表
PD我是你的真爱粉9 分钟前
LangChain 与 LangGraph 完全指南:核心组件、架构原理、编排机制与 LlamaIndex 集成
算法·架构·langchain
Ancelin安心9 分钟前
西工大noj(C/C++)100题参考题解及注意事项(2024)
c语言·c++·ide·windows·vscode·算法
倒酒小生16 分钟前
4月10日算法总结
图像处理·算法·计算机视觉
alphaTao17 分钟前
LeetCode 每日一题 2026/4/6-2026/4/12
python·算法·leetcode
李日灐17 分钟前
【优选算法3】二分查找经典算法面试题
开发语言·c++·后端·算法·面试·二分查找·双指针
独孤--蝴蝶20 分钟前
leetcode-动态规划三种问题的异同点
算法·leetcode·动态规划