快速排序javescript
时间: 2023-04-05 07:00:40 浏览: 86
基于javascript实现的快速排序
快速排序是一种常见的排序算法,它的基本思想是通过分治的方式将一个大问题分解成若干个小问题,然后逐步解决这些小问题,最终得到整个问题的解。在 JavaScript 中,可以使用递归的方式实现快速排序。具体实现方法可以参考以下代码:
function quickSort(arr) {
if (arr.length <= 1) {
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));
}
这段代码中,首先判断数组的长度是否小于等于 1,如果是,则直接返回该数组。否则,选择一个基准元素(pivot),将数组中小于基准元素的元素放到左边,大于基准元素的元素放到右边,然后递归地对左右两个子数组进行排序,最后将左子数组、基准元素、右子数组拼接起来,得到排序后的数组。
阅读全文