
稳定性:
同样数值,在排完序后是否能维持相对次序不变。
对于一般的数值无用,但对于具体应用有用。
快排,基础排序,指标最优,常数最优。
void quickSort(int[] arr) {
if (arr == null || arr.length < 2) {
return;
}
quickSort(arr, 0, arr.length - 1);
}
void quickSort(int[] arr, int l, int r) {
if (l < r) {
swap(arr, l + (int) (Math.random() * (r - l + 1)), r);
int[] p = partition(arr, l, r);
quickSort(arr, l, p[0] - 1);
quickSort(arr, p[1] + 1, r);
}
}
int[] partition(int[] arr, int l, int r) {
int less = l - 1;
int more = r;
while (l < more) {
if (arr[l] < arr[r]) {
swap(arr, ++less, l++);
} else if (arr[l] > arr[r]) {
swap(arr, --more, l);
} else {
l++;
}
}
swap(arr, more, r);
return new int[] { less + 1, more };
}
文章探讨了快速排序算法的稳定性问题,指出在特定应用中保持排序后数值的相对次序不变的重要性。文中提供的快速排序实现采用了随机选择枢轴以优化性能,通过递归地对子数组进行排序来确保效率。
&spm=1001.2101.3001.5002&articleId=130867022&d=1&t=3&u=d64765bf86d3455a89acc6c3a5e3b7fd)
4万+

被折叠的 条评论
为什么被折叠?



