//标准快排
function swap(arr, a, b) {
var temp = arr[a];
arr[a] = arr[b];
arr[b] = temp;
}
function quickSort2(arr, begin, end) {
if (begin >= end - 1) return;
var left = begin;
var right = end;
do {
do left++; while (left < right && arr[left] < arr[begin]);
do right--; while (right > left && arr[right] > arr[begin]);
if (left < right) swap(arr, left, right)
} while (left < right);
var swapPoint = left == right ? right - 1 : right;
swap(arr, begin, swapPoint);
quickSort2(arr, begin, swapPoint);
quickSort2(arr, swapPoint + 1, end);
}
function quickSort(arr) {
quickSort2(arr, 0, arr.length);
}
//quickSort(arr);
//console.log(arr);
function swap(arr, a, b) {
var temp = arr[a];
arr[a] = arr[b];
arr[b] = temp;
}
function quickSort2(arr, begin, end) {
if (begin >= end - 1) return;
var left = begin;
var right = end;
do {
do left++; while (left < right && arr[left] < arr[begin]);
do right--; while (right > left && arr[right] > arr[begin]);
if (left < right) swap(arr, left, right)
} while (left < right);
var swapPoint = left == right ? right - 1 : right;
swap(arr, begin, swapPoint);
quickSort2(arr, begin, swapPoint);
quickSort2(arr, swapPoint + 1, end);
}
function quickSort(arr) {
quickSort2(arr, 0, arr.length);
}
//quickSort(arr);
//console.log(arr);
全部评论
相关推荐
查看11道真题和解析 点赞 评论 收藏
分享
03-09 20:41
江西农业大学 后端工程师 dejavu06:本人也在学习,这是我个人总结的一些经验,我资质平平,不懂什么底层,只是把会的分享出来,希望大家轻点喷
点赞 评论 收藏
分享
02-04 17:01
南昌大学 Java 点赞 评论 收藏
分享
点赞 评论 收藏
分享