最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Javascript排序算法之计数排序的实例_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 21:21:29
文档

Javascript排序算法之计数排序的实例_javascript技巧

Javascript排序算法之计数排序的实例_javascript技巧:计数排序(Counting sort)是一种稳定的排序算法。计数排序使用一个额外的数组Count_arr,其中第i个元素是待排序数组Arr中值等于i的元素的个数。然后根据数组Count_arr来将Arr中的元素排到正确的位置。分为四个步骤:1.找出待排序的数组中最大和最小的元素2
推荐度:
导读Javascript排序算法之计数排序的实例_javascript技巧:计数排序(Counting sort)是一种稳定的排序算法。计数排序使用一个额外的数组Count_arr,其中第i个元素是待排序数组Arr中值等于i的元素的个数。然后根据数组Count_arr来将Arr中的元素排到正确的位置。分为四个步骤:1.找出待排序的数组中最大和最小的元素2


计数排序(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排序算法之计数排序的实例_javascript技巧:计数排序(Counting sort)是一种稳定的排序算法。计数排序使用一个额外的数组Count_arr,其中第i个元素是待排序数组Arr中值等于i的元素的个数。然后根据数组Count_arr来将Arr中的元素排到正确的位置。分为四个步骤:1.找出待排序的数组中最大和最小的元素2
推荐度:
标签: 技巧 js 示例
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top