码迷,mamicode.com
首页 > 编程语言 > 详细

数据结构——基数排序

时间:2017-03-16 18:45:40      阅读:215      评论:0      收藏:0      [点我收藏+]

标签:开始   http   调用   大小   wan   tar   有序   log   mod   

排序过程

以数组 A[6]={23, 14, 101, 72, 84, 11}为例,调用基数排序过程如下图所示:

技术分享

基本思想是:将整数按位切割成不同的数字,然后对每个数的同一位进行排序。
具体做法:将所有待排序数值统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序操作。这样从最低位排序一直到最高位排序完毕,数组就变成一个有序数组了。

源码实现

private static void sort(int[] A) {
    int mod = 1; // 位数
    int bit = 4; // 数组中值最大为4位数
    int[][] tempPlace = new int[10][A.length]; // 建造一个大小为10桶。一维为元素的某一位的值,二维为元素的值
    for (int z = 1;z <= bit;z++) { // 循环数组中最大值的位数
        int[] temp = new int[10]; // 保存每个tempPlace桶的当前下标
        for (int i = 0,j = 0;i < A.length;i++,j++) {
            int k = A[i]/mod % 10;
            tempPlace[k][temp[k]] = A[i];
            temp[k]++;
        }
        int length = 0;
        for (int i = 0;length<A.length;i++) {
            for (int j = 0;j < temp[i];j++) {
                A[length++] = tempPlace[i][j];
            }
        }
        mod*=10;
    }
}

参考资料

[1] 基数排序

[2] 算法导论, 8.3 - 基数排序

数据结构——基数排序

标签:开始   http   调用   大小   wan   tar   有序   log   mod   

原文地址:http://www.cnblogs.com/zhengbin/p/6560700.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!