QuickSort Hoare的分区无法正常工作

时间:2015-11-11 12:13:07

标签: sorting quicksort partition

您好,我现在已经尝试用Hoale的分区功能写了5个小时。我看了thisthis,甚至直接复制了"正确的"从这些问题中发挥作用,它仍然无法接近答案。这是我的#34;翻译"来自Cormen的书中的代码。

int Hpartition(int A[], int p, int r){
int x = A[p];
int i = p - 1;
int j = r + 1;
while(true){
    do{
        j--;
    }while(A[j] <= x);
    do{
        i++;
    }while(A[i] >= x);
    if(i < j){
        swap(A[i],A[j]);
    }
    else
        return j;
 }
}

快速排序:

void qs(int A[],int p,int r){
if(p<r){
    int q=Hpartition(A,p,r);
    qs(A,p,q-1);
    qs(A,q+1,r);
}
}

主:

int main(int argc, const char * argv[]) {
int tab[10];

for(int k=0;k<10;k++){
    cin >> tab[k];
}


qs(tab,0,9);

for(int i=0;i<10;i++){
    cout << tab[i] << " ";
}
return 0;
}

对于这些数据:

  

2 4 1 3 5 7 6 8 10 9

它产生了这个结果:

  

2 4 9 3 5 7 6 8 10 1

基于之前有关该主题的问题,我知道书中可能存在一些错误。但即使我应用之前问题的答案,它也不会起作用。

以下是本书的算法:

HOARE-PARTITION(A, p, r)
1 x = A[p]
2 i = p - 1
3 j = r + 1
4 while TRUE
5     repeat
6        j = j - 1
7     until A[j] <= x
8     repeat
9        i = i + 1
10    until A[i] >= x
11    if i < j
12        exchange A[i] with A[j]
13    else return j

提前感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

您有2个错误翻译书中的代码:

do{
     j--;
  }while(A[j] <= x);

你应该反过来说:

do{
     j--;
  }while(A[j] > x);

同样的:

do{
     i++;
  }while(A[i] >= x);

还有一个:

qs(A,p,q-1);
qs(A,q+1,r);

更改为:

qs(A,p,q);
qs(A,q+1,r);