手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >Javascript排序算法之计数排序的实例
Javascript排序算法之计数排序的实例
摘要:计数排序(Countingsort)是一种稳定的排序算法。计数排序使用一个额外的数组Count_arr,其中第i个元素是待排序数组Arr中值...

计数排序(Counting sort)是一种稳定的排序算法。计数排序使用一个额外的数组Count_arr,其中第i个元素是待排序数组Arr中值等于i的元素的个数。然后根据数组Count_arr来将Arr中的元素排到正确的位置。

分为四个步骤:

1.找出待排序的数组中最大和最小的元素

2.统计数组中每个值为i的元素出现的次数,存入数组Count_arr的第i项

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

4.反向遍历原数组:将每个元素i放在新数组的第Count_arr(i)项,每放一个元素就将Count_arr(i)减去1

实例:

复制代码 代码如下:

/**

* 计数排序是一个非基于比较的排序算法,

* 该算法于1954年由 Harold H. Seward 提出。

* 它的优势在于在对一定范围内的整数排序时,

* 它的复杂度为Ο(n+k)(其中k是整数的范围),

* 快于任何比较排序算法。

*

*/

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);

【Javascript排序算法之计数排序的实例】相关文章:

JavaScript获得指定对象大小的方法

javascript动态设置样式style实例分析

JavaScript中eval函数的问题

JavaScript正则表达式的分组匹配详解

javascript动态创建表格及添加数据实例详解

javascript去除空格方法小结

JavaScript中的sub()方法的使用介绍

javascript事件冒泡实例分析

JavaScript常用数组算法小结

JavaScript基于setTimeout实现计数的方法

精品推荐
分类导航