算法--桶排序与基数排序

1、实现

    public static void main(String[] args) {
        int[] src = { 5,6,7,16,15,14,13,12,11,10,8,9,9 };

        radixSort(src, 10, 2);
        print(src);

    //    bucketSort(src, 3, 20);
    //    print(src);
    }

    //桶排序
    public static void bucketSort(int[] data, int min, int max) {
        // 缓存数组
        int[] tmp = new int[data.length];
        // buckets用于记录待排序元素的信息
        // buckets数组定义了max-min个桶
        int[] buckets = new int[max - min];
        // 计算每个元素在序列出现的次数
        for (int i = 0; i < data.length; i++)
            //data[i] - min为相当于min的下标
            buckets[data[i] - min]++;

        for (int i = 1; i < max - min; i++)
            //算出下标的具体位置。如果有重复的 下标会跳跃
            buckets[i] = buckets[i] + buckets[i - 1];

        // 将data中的元素完全复制到tmp数组中
        System.arraycopy(data, 0, tmp, 0, data.length);
        // 根据buckets数组中的信息将待排序列的各元素放入相应位置
        for (int k = data.length - 1; k >= 0; k--) {
            int buckIndex = tmp[k] - min;//相对下标
            //根据相对下标得出tmp[k]的具体位置  最重要的转换
            //--buckets是因为有相同的数据,下标可以减一
            int index = --buckets[buckIndex];
            data[index] = tmp[k];
        }
    }

    //基数排序
    public static void radixSort(int[] data, int radix, int d) {
        // 缓存数组
        int[] tmp = new int[data.length];
        // buckets用于记录待排序元素的信息
        int[] buckets = new int[radix];

        for (int i = 0, rate = 1; i < d; i++) {
            Arrays.fill(buckets, 0);
            System.arraycopy(data, 0, tmp, 0, data.length);

            for (int j = 0; j < data.length; j++) {
                //获取数字rate位的数字  如123的十位 (123/10)%10 = 2
                int subKey = (tmp[j] / rate) % radix;
                //出现的次数
                buckets[subKey]++;
            }

            for (int j = 1; j < radix; j++)
                //计算下标
                buckets[j] = buckets[j] + buckets[j - 1];

            for (int m = data.length - 1; m >= 0; m--) {
                int subKey = (tmp[m] / rate) % radix;
                //类似桶排序
                data[--buckets[subKey]] = tmp[m];
            }
            //进一位 再次处理
            rate *= radix;
        }

    }

    public static void print(int src[]){
        for (int i = 0; i < src.length; i++) {
            System.out.print(src[i] + "  ");
        }
        System.out.println();
    }

参考:
http://www.cnblogs.com/kkun/archive/2011/11/23/2260267.html
http://www.cnblogs.com/skywang12345/p/3603669.html
http://www.cnblogs.com/oumyye/p/4522467.html
http://blog.csdn.net/apei830/article/details/6596104

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值