/**
* 计数排序
* 分配一个临时数组,长度比待排序列表中最大值大1
* 遍历待排序数组,用元素作为临时数组的下标,并计数
* 最后遍历临时数组,按顺序取值即可
* @param {*} arr
*/
function countSort(arr) {
var max = Math.max.apply(null, arr)
var bucket = new Array(max + 1)
var length = arr.length
var bucketLen = max + 1
var sortedIndex = 0
for (var i = 0; i < length; i++) {
if (!bucket[arr[i]]) {
bucket[arr[i]] = 0
}
bucket[arr[i]]++
}
for (var j = 0; j < bucketLen; j++) {
for (var x = 0; x < bucket[j]; x++) {
if (bucket[j] > 0) {
arr[sortedIndex++] = j
}
}
}
console.log(arr)
}
js排序算法-计数排序
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
相关阅读更多精彩内容
- 今天要讲的三种排序算法的时间复杂度都是O(n),因为它们的时间复杂度是线性的,所以我们把这类排序算法叫做线...
- 桶排序、计数排序、基数排序和前面讲的那些排序有所不同,不是基于比较的排序算法,而是一种线性排序。他们的时间复杂度更...
- 本文只是自己的笔记,并不具备过多的指导意义。 代码的初衷是便于理解,网上大神优化过的代码很多,也不建议在项目中co...
- 数据结构与算法——计数排序、桶排序、基数排序 计数排序 计数排序有如下四个步骤。 首先会对每个输入进行频率统计,得...