zoukankan      html  css  js  c++  java
  • JS排序算法总结:(八)基数排序

    目的:掌握 基数排序 的 基本思想与过程、代码实现、时间复杂度

    1、基本思想与过程:(只针对数字)

      (1)首先确定基数为10,数组的长度也就是10.每个数都会在这10个数中寻找自己的位置。

      (2)不同于BinSort会直接将数放在数组的下标处,如将 [34] 放在下标为34的位置,即a[34] = 34;基数排序是将34分开为3和4,第一轮排序根据最末位放在数组的下标4处,第二轮排序根据倒数第二位放在数组的下

    标3处,然后遍历数组即可。

    2、代码实现:

    function RadixLSDSort (arr, digit) {
        const radix = 10;   // 基数,以10进制来进行排序
        var i = 0, 
            j = 0,
            count = Array(radix), // 0~9的桶
            len = arr.length,
            bucket = Array(len);
        // 利用LSD,也就是次位优先
        for (var d = 0; d < digit; d++) {
            for (i = 0; i < radix; i++) {
                count[i] = 0;
            }
            // 向各个桶中添加元素,并统计出每个桶中装的个数
            for (i = 0; i < len; i++) {
                j = getDigit(arr[i], d);
                count[j]++;
            }
            // count的越往后值最大,最大值为arr.length
            // count数组的值为,该位数值为该索引的数字总数
            for (i = 1; i < radix; i++) {
                count[i] = count[i] + count[i - 1];
            }
            // 按照桶的顺序将导入temp中
            for (i = len - 1; i >= 0; i--) {
                j = getDigit(arr[i], d);
                bucket[count[j] - 1] = arr[i];
                count[j]--; 
            }
            // 将已经根据相应位数排好的序列导回arr中
            for (i = 0; i < len; i++) {
                arr[i] = bucket[i];
            }
        }   
        return arr
    }
    
    // 获得每位的数字
    function getDigit(x,d){
        var a = [ 1,10,100,1000,10000,100000,1000000,10000000,100000000,1000000000];
        return (Math.floor(x / a[d]) % 10);
    }

    3、时间复杂度:O(d(n+r),其中:d为待排列数字的最大位数,n为待排序列的长度,r为进制数 

  • 相关阅读:
    自定义异常
    异常的处理方式之二:声明异常(throws子句)
    异常的处理方式之一:捕获异常
    CheckedException已检查异常
    Range Sum Query
    cmd命令结束占用tomcat的进程
    原生js实现瀑布流
    js实现选项卡切换
    (转载)用ul做横向导航
    帝国CMS视频
  • 原文地址:https://www.cnblogs.com/CassieHouse/p/9573406.html
Copyright © 2011-2022 走看看