计数排序
- function bucketSort(arr, bucketSize) {
- if (arr.length === 0) {
- return arr;
- }
- var i;
- var minValue = arr[0];
- var maxValue = arr[0];
- for (i = 1; i < arr.length; i++) {
- if (arr[i] < minValue) {
- minValue = arr[i]; //输入数据的最小值
- } else if (arr[i] > maxValue) {
- maxValue = arr[i]; //输入数据的最大年夜值
- }
- }
- //桶的初始化
- var DEFAULT_BUCKET_SIZE = 5; //设置桶的默认数量为5
- bucketSize = bucketSize || DEFAULT_BUCKET_SIZE;
- var bucketCount = Math.floor((maxValue - minValue) / bucketSize) + 1;
- var buckets = new Array(bucketCount);
- for (i = 0; i < buckets.length; i++) {
- buckets[i] = [];
- }
- //应用映射函数将数据分派到各个桶中
- for (i = 0; i < arr.length; i++) {
- buckets[Math.floor((arr[i] - minValue) / bucketSize)].push(arr[i]);
- }
- arr.length = 0;
- for (i = 0; i < buckets.length; i++) {
- insertionSort(buckets[i]); //对每个桶进行排序,这里应用了插入排序
- for (var j = 0; j < buckets[i].length; j++) {
- arr.push(buckets[i][j]);
- }
- }
- return
推荐阅读
对于这种的办法:大年夜网页点击下载时要看看下载的文件名,绿色版的软件一般是目标软件的拼音或者英订婚名,多半是紧缩包(就算是安装版也要打包一下的),所以如不雅下载文件名是无序字符串,以及是exe文件,十有八九>>>详细阅读
本文标题:JavaScript中常见排序算法详解
地址:http://www.17bianji.com/lsqh/39153.html
1/2 1