作家
登录

JavaScript中常见排序算法详解

作者: 来源: 2017-11-22 16:00:13 阅读 我要评论

 
  •     return arr; 
  • 计数排序

    1. function bucketSort(arr, bucketSize) { 
    2.     if (arr.length === 0) { 
    3.       return arr; 
    4.     } 
    5.   
    6.     var i; 
    7.     var minValue = arr[0]; 
    8.     var maxValue = arr[0]; 
    9.     for (i = 1; i < arr.length; i++) { 
    10.       if (arr[i] < minValue) { 
    11.           minValue = arr[i];                //输入数据的最小值 
    12.       } else if (arr[i] > maxValue) { 
    13.           maxValue = arr[i];                //输入数据的最大年夜值 
    14.       } 
    15.     } 
    16.   
    17.     //桶的初始化 
    18.     var DEFAULT_BUCKET_SIZE = 5;            //设置桶的默认数量为5 
    19.     bucketSize = bucketSize || DEFAULT_BUCKET_SIZE; 
    20.     var bucketCount = Math.floor((maxValue - minValue) / bucketSize) + 1;   
    21.     var buckets = new Array(bucketCount); 
    22.     for (i = 0; i < buckets.length; i++) { 
    23.         buckets[i] = []; 
    24.     } 
    25.   
    26.     //应用映射函数将数据分派到各个桶中 
    27.     for (i = 0; i < arr.length; i++) { 
    28.         buckets[Math.floor((arr[i] - minValue) / bucketSize)].push(arr[i]); 
    29.     } 
    30.   
    31.     arr.length = 0; 
    32.     for (i = 0; i < buckets.length; i++) { 
    33.         insertionSort(buckets[i]);                      //对每个桶进行排序,这里应用了插入排序 
    34.         for (var j = 0; j < buckets[i].length; j++) { 
    35.             arr.push(buckets[i][j]);                       
    36.         } 
    37.     } 
    38.   
    39.     return

        推荐阅读

        为啥你电脑越来越卡 别人却能战五年?

      对于这种的办法:大年夜网页点击下载时要看看下载的文件名,绿色版的软件一般是目标软件的拼音或者英订婚名,多半是紧缩包(就算是安装版也要打包一下的),所以如不雅下载文件名是无序字符串,以及是exe文件,十有八九>>>详细阅读


      本文标题:JavaScript中常见排序算法详解

      地址:http://www.17bianji.com/lsqh/39153.html

    关键词: 探索发现

    乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

    网友点评
    自媒体专栏

    评论

    热度

    精彩导读
    栏目ID=71的表不存在(操作类型=0)