国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Javascript排序算法之計數(shù)排序的實例

2024-05-06 16:03:46
字體:
供稿:網(wǎng)友
計數(shù)排序是一種高效的線性排序,它通過計算一個集合中元素楚翔的次數(shù)來確定集合如何排列,計數(shù)排序不需要進行數(shù)據(jù)的比較,所有他的運行效率前面介紹的都高

計數(shù)排序(Counting sort)是一種穩(wěn)定的排序算法。計數(shù)排序使用一個額外的數(shù)組Count_arr,其中第i個元素是待排序數(shù)組Arr中值等于i的元素的個數(shù)。然后根據(jù)數(shù)組Count_arr來將Arr中的元素排到正確的位置。
分為四個步驟:
1.找出待排序的數(shù)組中最大和最小的元素
2.統(tǒng)計數(shù)組中每個值為i的元素出現(xiàn)的次數(shù),存入數(shù)組Count_arr的第i項
3.對所有的計數(shù)累加(從Count_arr中的第一個元素開始,每一項和前一項相加)
4.反向遍歷原數(shù)組:將每個元素i放在新數(shù)組的第Count_arr(i)項,每放一個元素就將Count_arr(i)減去1

實例:

復制代碼 代碼如下:


/**
 * 計數(shù)排序是一個非基于比較的排序算法,
 * 該算法于1954年由 Harold H. Seward 提出。
 * 它的優(yōu)勢在于在對一定范圍內(nèi)的整數(shù)排序時,
 * 它的復雜度為Ο(n+k)(其中k是整數(shù)的范圍),
 * 快于任何比較排序算法。
 *
 */

function countSort(arr, min, max) {
    var i, z = 0, count = [];

    for (i = min; i <= max; i++) {
        count[i] = 0;
    }

    for (i=0; i < arr.length; i++) {
        count[arr[i]]++;
    }

    for (i = min; i <= max; i++) {
        while (count[i]-- > 0) {
            arr[z++] = i;
        }
    }
    return arr;
}

// test

var i, arr = [];

for (i = 0; i < 100; i++) {
    arr.push(Math.floor(Math.random() * (141)));
}

countSort(arr, 0, 140);

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 绍兴县| 申扎县| 密云县| 定边县| 五峰| 潞城市| 刚察县| 仁怀市| 富裕县| 柳河县| 梁平县| 苍溪县| 团风县| 潜山县| 包头市| 梧州市| 庆安县| 桐乡市| 阿拉善右旗| 河源市| 临汾市| 商城县| 灯塔市| 莱芜市| 周至县| 乌拉特中旗| 原阳县| 彭州市| 博罗县| 清丰县| 英山县| 安丘市| 定南县| 商丘市| 朝阳区| 隆昌县| 陆川县| 泸西县| 孝义市| 台北市| 桃源县|