前端算法之计数排序

计数排序不是基于比较的排序算法,其核心在于将输入的数据值转化为键存储在额外开辟的数组空间中。作为一种线性时间复杂度的排序,计数排序要求输入的数据必须是有确定范围的整数。

8.1 算法描述
  • 找出待排序的数组中最大和最小的元素;

  • 统计数组中每个值为i的元素出现的次数,存入数组C的第i项;

  • 对所有的计数累加(从C中的第一个元素开始,每一项和前一项相加);

  • 反向填充目标数组:将每个元素i放在新数组的第C(i)项,每放一个元素就将C(i)减去1。

    function countingSort(arr, maxValue) {
    var bucket =new Array(maxValue + 1),
    sortedIndex = 0;
    arrLen = arr.length,
    bucketLen = maxValue + 1;

    复制代码
      for (var i = 0; i < arrLen; i++) {
          if (!bucket[arr[i]]) {
              bucket[arr[i]] = 0;
          }
          bucket[arr[i]]++;
      }
    
    
      for (var j = 0; j < bucketLen; j++) {
          while(bucket[j] > 0) {
              arr[sortedIndex++] = j;
              bucket[j]--;
          }
      }
    
    
      return arr;

    }

相关推荐
AI科技星4 分钟前
基于空间光速螺旋第一性原理的电荷本源定义与电场时空协变方程的完整推导、严格证明及全尺度数值验证
c语言·开发语言·算法·机器学习·数据挖掘
云泽80810 分钟前
蓝桥杯算法精讲:深剖分治算法及其经典应用
算法·职场和发展·蓝桥杯
志摩凛11 分钟前
范畴论——前端与计算机领域的“抽象工具箱”:该用则用,该弃则弃
算法·架构
2401_8579182913 分钟前
C++与自动驾驶系统
开发语言·c++·算法
乐分启航16 分钟前
【无标题】
深度学习·算法·目标检测·transformer·迁移学习
GfovikS0610024 分钟前
C++中的函数式编程
开发语言·c++·算法
2401_8579182925 分钟前
C++中的构建器模式
开发语言·c++·算法
穿条秋裤到处跑29 分钟前
每日一道leetcode(2026.03.25):等和矩阵分割 I
算法·leetcode·矩阵
实心儿儿37 分钟前
算法9:相同的树
算法·leetcode·职场和发展
another heaven40 分钟前
【计算机 字符编码类型及其应用场景详解】
数据结构·字符编码