博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
桶排序与基数排序
阅读量:6070 次
发布时间:2019-06-20

本文共 2622 字,大约阅读时间需要 8 分钟。

hot3.png

桶排序:限定场景在0-n 有数值范围内一个无序数列a[k],对无序数列进行分n+1个桶,然后从桶中比较获取回来一个有序数列。

        排序方法:1、建立0-n数值的(n+1)一个桶,然后对无序数列中的a[k]等于对应桶(n)的数值进行累加统计  2、 遍历整个桶,数值和桶对应编号(n)相等的进行赋值给新的数列,并对其桶统计值自减,直至为0. 这样得出来就是一个有序的数列。

桶排序举个例子,有一个整数序列,0, 133, 45, 386, 106,45下面是排序过程:

1、首先计算出最大桶,最大桶是386;

2、对不同的桶进行统计,{1(桶编号0只有1个数值),0(桶编号为1没有数值,.................2(b编号45 含有2个数值),..............1(编号386)}

3、最后对桶进行遍历 ,桶含有值的 依次装入 一个新的序列数组中{0, 45,45, 106, 133, 386} 完成排序

 

基数排序:核心思想是将整数按位数切割成不同的数字,然后按每个位数分别比较。

      排序方法:比如有个数列{123,456,78}。我们可以通过获取最大数值的位数,通过对不足的前面补0,然后对这个序列进行个位、十位、百位的0-9进行分桶 进行排序,最后得出来就是个有序数列。

     基数排序这儿思考一个问题,为什么将整数按位数进行切割后,按照位数进行排序,不使用冒泡、快速排序这些算法呢。认真想下,其实比较简单,冒泡算法还是快速排序本来就比桶排序比较来说,长的很多,按位数进行排序后,对其做冒泡排序,时间复杂度等于 K(总位数)* n*(n-1) ,比原来的冒泡排序还更复杂了,这样还不如就直接使用冒泡排序就可以直接一次完成排序,快速排序也有同样差不多道理,桶排序就是因为时间效率远远大的多于比如冒泡、快速排序,所以其实这儿基数排序相对说是桶排序的一个折中 空间和时间复杂度的算法。

基数排序举个例子,有一个整数序列,0, 133, 45, 386, 106,下面是排序过程:

第一次排序,个位,000 133 045 386 106,无任何变化

第二次排序,十位,000 106 133 045 386
第三次排序,百位,000 045 106 133 386
最终结果,0, 45, 106, 133, 386, 排序完成。
 

下面附桶排序和基数排序个人实现代码:

private static int[] bucketSort(int[] array) {

        int max = 0; 
        for(int i=0;i<array.length;i++){
            if(max<array[i]){
                max= array[i];
            }
        }
        max += 1; //计算得出桶最大值,确定最大桶
        int[] data = new int[array.length];
        int[] bucket = new int[max];
        for (int i = 0; i < array.length; i++) {//n
            bucket[array[i]]++; // 对数列中进行装桶
        }
        int i = 0;
        int j = 0;

        while (i < max) {// 遍历所有桶中含有 统计数值大于0的数值,进行有序装载对应的数据,最后出来有序数列

            if (bucket[i] > 0) {
                while ((bucket[i]--) > 0) {
                    data[j++] = i;
                }
            }
            i++;
        }
        return data;
    }

//基数排序

public static void radixSort(int[] data) {

        int length = data.length;

        // 获取指数的位数

        int count = getMaxCount(data, length); //获取最大位数

        // 对各个位数进行排序

        int index = 0;//

        while (index < count) {
            data = bucketSort(data, index, count);
            index++;
        }

    }

 

    private static int getMaxCount(int[] data, int length) {

        int max = 0;
        for (int i = 0; i < length; i++) {
            if (data[i] > max) {
                max = data[i];
            }
        }
        int count = 1;
        int n = 10;
        while (max / n != 0) {// 1021 ,20
            n = n * 10;
            count++;
        }
        return count;
    }

//按位数进行桶排序

private static int[] bucketSort2(int[] array, int index, int count) {

        int bucketLength = 10;

        int multiNum = (int) Math.pow(10, index);

        int[] data = new int[array.length];
        int[] bucket = new int[bucketLength];
        int i;
        for (i = 0; i < array.length; i++) {// n
            // array 数据转化为到具体位数进行排序
            int temp = (array[i] / multiNum) % 10;
            bucket[temp]++;
        }

        for (i = 1; i < 10; i++) {

            bucket[i] += bucket[i - 1];
        }

        for (i = array.length - 1; i >= 0; i--) {

            data[bucket[(array[i] / multiNum) % 10] - 1] = array[i];
            bucket[(array[i] / multiNum) % 10]--;
        }

        for (i = 0; i < array.length; i++) {

            array[i] = data[i];
        }

        return array;

    }
    

    未完后面待续

    

 

转载于:https://my.oschina.net/u/3318187/blog/2244880

你可能感兴趣的文章
无锡格瑞驰车业 ipad做汽车导航
查看>>
C Primer Plus 第5章 运算符、表达式和语句 5.3 其他运算符
查看>>
Swift 和 Objective-C 混编后对ipa包大小的影响
查看>>
通用户权限管理设计_Index
查看>>
Win2008 R2 IIS7.5+PHP5(FastCGI)+MySQL5环境搭建教程
查看>>
如何给VSFTP增加用户,只能访问指定目录
查看>>
http 错误代码表
查看>>
phalcon使用namespace
查看>>
centos5.8 安装tomcat7、solr4.9
查看>>
Openbiz Cubi 快速应用开发向导
查看>>
mysql 从一个表中查数据,插入另一个表
查看>>
ios8新特性屏幕适配之sizeclass
查看>>
pcDuino安装USB声卡实现放歌和录音功能
查看>>
C++中string型字符串的使用示例
查看>>
警惕! 超过18000个安卓应用正在窃取你的短信
查看>>
无法获取model上的排他锁
查看>>
CentOS6配置ffmpeg
查看>>
快速安装mysql方式
查看>>
CSS中margin-top对父级元素产生作用的问题
查看>>
javascript闭包浅析
查看>>