/**
* 基数排序
* 觉得这个排序算法很巧妙。
* 可以从低位到高位排,或者高位到低位排,下面是低位到高位
* 先排每个数个位数字[0-9],根据数字放到不同桶中
* 然后将桶连接,在按每个数十位数字[0-9]排
* 依次类推,根据列表中最大数字位数循环就行
* @param {*} arr
* @param {*} maxDigit
*/
function radixSort(arr, maxDigit) {
var mod = 10
var dev = 1
var count = []
for (var i = 0; i < maxDigit; i++, dev *= 10, mod *= 10) {
for (var j = 0; j < arr.length; j++) {
var bucket = parseInt((arr[j] % mod) / dev)
console.log(bucket, arr[j])
if (!count[bucket]) {
count[bucket] = []
}
count[bucket].push(arr[j])
}
var sortedIndex = 0
for (var x = 0; x < count.length; x++) {
// console.log(count[x])
if (count[x]) {
count[x].map(item => {
// console.log(item)
arr[sortedIndex++] = item
})
}
}
//清空之前的桶
count = []
}
console.log(arr)
}
radixSort(arr, 2)
js算法排序-基数排序
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
相关阅读更多精彩内容
- 今天要讲的三种排序算法的时间复杂度都是O(n),因为它们的时间复杂度是线性的,所以我们把这类排序算法叫做线...
- 桶排序、计数排序、基数排序和前面讲的那些排序有所不同,不是基于比较的排序算法,而是一种线性排序。他们的时间复杂度更...
- 桶排序和基数排序均属于分配排序。分配排序的基本思想:排序过程无须比较关键字,而是通过用额外的空间来"分配"和"收集...
- 基数排序(RadixSort)也是八大排序算法之一,它在棋牌游戏中的应用非常常见。基数排序是采用“分配”与“收集”...
- 4月21日起,依据《国家发展改革委关于改革完善高铁动车组旅客票价政策的通知》,我国东南沿海时速200~250公里的...