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

javascript 快速排序方法

时间:2017-05-17 11:56:18      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:简单   数组   turn   script   使用   数据集   子集   过程   数据   

"快速排序"的思想很简单,整个排序过程只需要三步:

(1)在数据集之中,选择一个元素作为"基准"(pivot)。

(2)所有小于"基准"的元素,都移到"基准"的左边;所有大于"基准"的元素,都移到"基准"的右边。

(3)对"基准"左边和右边的两个子集,不断重复第一步和第二步,直到所有子集只剩下一个元素为止。

 

var function quickSort(arr){

  if(arr.length<=0){

    return arr;

  }

    var pivotIndex = Math.floor(arr.length / 2) ;

   var pivot = arr.splice(pivotIndex, 1)[0];

   var left = [];

   var right = [];

  for (var i = 0; i < arr.length; i++){

    if (arr[i] < pivot) {

      left.push(arr[i]);

    } else {

      right.push(arr[i]);

    }

  }

  return quickSort(left).concat([pivot], quickSort(right));//使用递归不断重复这个过程,就可以得到排序后的数组。

}

 

 

javascript 快速排序方法

标签:简单   数组   turn   script   使用   数据集   子集   过程   数据   

原文地址:http://www.cnblogs.com/winyh/p/6866132.html

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