码迷,mamicode.com
首页 > 编程语言 > 详细

JS排序之快速排序

时间:2018-01-25 18:24:33      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:cat   ret   div   sts   span   function   索引   else   post   

JS排序之快速排序

一个数组中的数据,选择索引为(2/数组长度)的那个数据作为基数,数组中的其他数据与它对比,比它数值小的放在做数组,比它数值大的放在右数组,最后组合 左数组+基数+右数组,其中,左数组和右数组再调该方法,也就是递归调用,当数组长度小于2时,停止。

 

<script>
var arr=[12,56,15,65,55,90,21,9];
function fastSort(arr){
    if(arr.length<2){
        return arr;
    }
    var left=[];
    var right=[];
    var midIndex=Math.floor(arr.length/2);
    var flagNum=arr.splice(midIndex,1)[0];
    for(i=0;i<arr.length;i++){
        if(arr[i]<flagNum){
            left.push(arr[i]); 
        }else{
            right.push(arr[i])
        }
    }
    return fastSort(left).concat([flagNum],fastSort(right));
}
console.log(fastSort(arr));
</script>

 

  

 

JS排序之快速排序

标签:cat   ret   div   sts   span   function   索引   else   post   

原文地址:https://www.cnblogs.com/pengxiangchong/p/8352295.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!