/**
* 基數(shù)排序
* 覺(jué)得這個(gè)排序算法很巧妙。
* 可以從低位到高位排,或者高位到低位排,下面是低位到高位
* 先排每個(gè)數(shù)個(gè)位數(shù)字[0-9],根據(jù)數(shù)字放到不同桶中
* 然后將桶連接,在按每個(gè)數(shù)十位數(shù)字[0-9]排
* 依次類推,根據(jù)列表中最大數(shù)字位數(shù)循環(huán)就行
* @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算法排序-基數(shù)排序
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- 今天要講的三種排序算法的時(shí)間復(fù)雜度都是O(n),因?yàn)樗鼈兊臅r(shí)間復(fù)雜度是線性的,所以我們把這類排序算法叫做線...
- 桶排序、計(jì)數(shù)排序、基數(shù)排序和前面講的那些排序有所不同,不是基于比較的排序算法,而是一種線性排序。他們的時(shí)間復(fù)雜度更...
- 桶排序和基數(shù)排序均屬于分配排序。分配排序的基本思想:排序過(guò)程無(wú)須比較關(guān)鍵字,而是通過(guò)用額外的空間來(lái)"分配"和"收集...
- 基數(shù)排序(RadixSort)也是八大排序算法之一,它在棋牌游戲中的應(yīng)用非常常見(jiàn)。基數(shù)排序是采用“分配”與“收集”...
- 4月21日起,依據(jù)《國(guó)家發(fā)展改革委關(guān)于改革完善高鐵動(dòng)車(chē)組旅客票價(jià)政策的通知》,我國(guó)東南沿海時(shí)速200~250公里的...