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

来源:互联网 发布:linux一键安装lamp 编辑:程序博客网 时间:2024/06/06 19:45

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

原创粉丝点击