作家
登录

JavaScript中常见排序算法详解

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

  •  
  •     if (left < right) { 
  •  
  •         partitionIndex = partition(arr, leftright); 
  •  
  •         quickSort(arr, left, partitionIndex-1); 
  •  
  •         quickSort(arr, partitionIndex+1, right); 
  •  
  •     } 
  •  
  •     return arr; 
  •  
  • }  
  •  
  • function partition(arr, left ,right) {     //分区操作 
  •  
  •     var pivot = left,                      //设定基准值(pivot) 
  •  
  •         index = pivot + 1; 
  •  
  •     for (var i = index; i <= right; i++) { 
  •  
  •         if (arr[i] < arr[pivot]) { 
  •  
  •             swap(arr, i, index); 
  •  
  •             index++; 
  •  
  •         }         
  •  
  •     } 
  •  
  •     swap(arr, pivot, index - 1); 
  •  
  •     return index-1; 
  •  
  • }  
  •  
  • function swap(arr, i, j) { 
  •  
  •     var temp = arr[i]; 
  •  
  •     arr[i] = arr[j]; 
  •  
  •     arr[j] = temp
  •  
  • 堆排序可以说是一种应用堆的概念来排序的选择排序。分为两种办法:

    • 大年夜顶堆:每个节点的值都大年夜于或等于其子节点的值,在堆排序算法顶用于升序分列
    • 小顶堆:每个节点的值都小于或等于其子节点的值,在堆排序算法顶用于降序分列

    堆排序动图演示

    堆排序JavaScript代码实现:

    1. var len;    //因为声明的多个函数都须要数据长度,所以把len设置成为全局变量  

        推荐阅读

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

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


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

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

    关键词: 探索发现

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

    网友点评
    自媒体专栏

    评论

    热度

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