快速排序取决于选择数据透视

时间:2019-01-25 13:26:35

标签: c algorithm sorting

这是我的快速排序算法,包括分区和交换。当我选择数组的最后一个元素作为枢轴时(在quicksort函数:int r = partition(a, n, n);中),效果很好,但是当取第一个元素:int r = partition(a, n, s);

时失败
void Swap(int a[], int l, int r){
int tmp = a[l];
a[l] = a[r];
a[r] = tmp;
}

int partition(int a[], int n, int p) {
Swap(a, p, n);
int l = 0;
for (int i = 1; i <= n - 1; i++) {
    if (a[i] <= a[n]) {
        l += 1;
        Swap(a, l, i);
        }
    }
Swap(a, p, l + 1);
return l + 1;
}

void quicksort(int a[], int s, int n) {
if (s < n) {
    int r = partition(a, n, n);
    quicksort(a, s, r - 1);
    quicksort(a, r + 1, n);
    }
}

1 个答案:

答案 0 :(得分:0)

是的,问题出在partition过程中,这一过程是正确的:

int partition(int a[], int p, int r) {
int t = a[r];
int i = p - 1;
for (int j = p; j < r;j++){
    if (a[j] <= t) {
        i += 1;
        std::swap(a[i], a[j]);
    }
}
std::swap(a[i + 1], a[r]);
return i + 1;

}