我正在尝试编写一个程序来计算快速排序程序中的比较次数。
这是我的代码
package algo_quicksort;
public class Algo_quicksort {
public static int partition(int[]A,int p,int r){
int x=A[p];
int i=p+1;
int temp;
for(int j=p+1;j<r;j++){
if(A[j]<x){//if A[j] is bigger than the pivot do nothing
temp=A[j];
A[j]=A[i];
A[i]=temp;
i++;
}
}
temp=A[p];
A[p]=A[i-1];
A[i-1]=temp;
return i-1;
}
public static long quickSort(int[]A,int startPos,int length){
if(length==1){
return 0;
}
else{
if(startPos<length){
int pivot= partition(A,0,length);
quickSort(A,startPos,pivot+1);
quickSort(A, pivot+2,length);
return length-startPos-1;
}
else{
return 0;
}
}
}
public static void main(String[] args) {
int a[]={3,2,4};
System.out.println("# of comparisons is: " +quickSort(a,0,a.length));
System.out.println("A[] after quicksort is: ");
for(int i=0;i<a.length;i++){
System.out.print(a[i]+" ");
}
}
}
它适用于任何大小为 3 或更小的数组,但如果它比这更大,它会在递归调用时给我一个 stackoverflow 异常,我尝试调试我的代码,但无法弄清楚它哪里出错了?