十大基本排序算法(基数排序)

算法基本流程图解: 后续补
算法时间复杂度 : O(n)
算法设计思想: 

取得所有数的数位并统一为相同的长度,数位较短的数字前面补零。从低位开始排序,分别放入0~9个队列中,然后采用先进先出的原则进行收集;在按照高位排序,然后在收集;依次类推,直到最高位,最终得到排好序的数列。

代码实现: 


    private void sort(int[] arr) {
        int max = arr[0];
        // 最大值
        for (int i = 1; i < arr.length; i++) {
            if (max < arr[i]) max = arr[i];
        }
        // 位数
        int len = (max + "").length();
        List<Integer>[] bucket = new ArrayList[10];
        for (int i = 0; i < bucket.length; i++) {
            bucket[i] = new ArrayList<>();
        }
        int j = 0;
        while (j < len) {
            // 入桶
            for (int i = 0; i < arr.length; i++) {
                int idx = (int) (arr[i] / Math.pow(10, j)) % 10;
                bucket[idx].add(arr[i]);
            }
            int temp = 0;
            // 出桶
            for (int i = 0; i < bucket.length; i++) {
                for (int z = 0; z < bucket[i].size(); z++) {
                    arr[temp++] = bucket[i].get(z);
                }
                bucket[i].clear();
            }
            j++;
        }
    }

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值