如何避免快速排序堆栈溢出

时间:2014-09-19 07:31:54

标签: c++ sorting stack-overflow quicksort

当我在C ++中使用快速排序时,Visual Studio 2013会警告堆栈溢出错误。

如何解决此问题?在这个问题上,我不能使用这种快速排序吗?

我认为因为我在快速排序中使用递归,所以这个问题会产生很多深度内存堆栈。

这是代码。

int partition(int **array, int p, int r){

    int x = array[r][1];
    int i = p - 1;
    int j;
    int temp0, temp1;

    for (j = p; j < r; j++){
        if (array[j][1] <= x){
            i++;

            temp0 = array[i][0];
            temp1 = array[i][1];

            array[i][0] = array[j][0];
            array[i][1] = array[j][1];

            array[j][0] = temp0;
            array[j][1] = temp1;
        }
    }

    temp0 = array[i + 1][0];
    temp1 = array[i + 1][1];

    array[i + 1][0] = array[r][0];
    array[i + 1][1] = array[r][1];

    array[r][0] = temp0;
    array[r][1] = temp1;

    return i + 1;
}

void quickSort(int **array, int p, int r){
    int q;
    if (p < r){
        q = Partition(array, p, r);
        quickSort(array, p, q - 1);
        quickSort(array, q + 1, r);
    }
}

1 个答案:

答案 0 :(得分:1)

在你的代码中,你总是先做前半部分(数组,p,q - 1)。这可能导致堆栈溢出。相反,总是首先执行两个子数组中最小的一个并强制尾递归。

void quickSort(int **array, int p, int r){
    while (r - p >= 1){
        int q = Partition(array, p, r);

        if ((q - 1) - p <= r - (q + 1)){
            quicksort(array, p, q - 1);

            // Prepare for tail recursion
            p = q + 1;
        }
        else {
            quicksort(array, q + 1, r);

            // Prepare for tail recursion
            r = q - 1;
       }
    }
}

这样做,可以证明堆栈上递归调用的最大数量是log_ {2}(n)。