2017-08-14 121 views
0

在阅读合并排序后,我已经编写了下面的Java代码。运行代码时没有错误,但合并排序不排序数组。它只是返回原始的未排序数组。我不能为了我的生活找出问题的症结所在。我感谢任何线索。合并排序不排序数组

public class mergeSort { 

public void mergeSort(int array[], int n){ 

    if(n<2) return; 
    int m=n/2; 
    int left[]=new int[m]; 
    int right[]=new int[n-m]; 
    int i; 

    for(i=0; i<m;i++){ 
     left[i]=array[i]; 
    } 
    for(i=m; i<n;i++){ 
     right[i-m]=array[i]; 
    } 
    printArray(left); 
    printArray(right); 
    mergeSort(left, m); 
    mergeSort(right, n-m); 
    merge(array, left, m, right, m-n); 
} 

private void merge(int[] array, int[] left, int leftCount, int[] right, int rightCount) { 
    int i=0,j=0,k=0; 

    while(i<leftCount && j< rightCount){ 
     if(left[i]<=right[j]){ 
      array[k]=left[i]; 
      i++; 
      k++; 
     }else{ 
      array[k]=right[j]; 
      j++; 
      k++; 
     } 
    } 

    while(i<leftCount){ 
     array[k]=left[i]; 
     i++; 
     k++; 
    } 
    while(j<rightCount){ 
     array[k]=right[j]; 
     j++; 
     k++; 
    } 

} 
static void printArray(int arr[]) 
    { 
     int n = arr.length; 
     for (int i=0; i<n; ++i) 
      System.out.print(arr[i] + " "); 
     System.out.println(); 
    } 

public static void main(String[] args){ 
    int a[]={3,2,1,7,9,8}; 
    printArray(a); 


    mergeSort m=new mergeSort(); 
    m.mergeSort(a, a.length); 

    printArray(a); 
} 

}

回答

0

的leftCount和rightCount您传递给合并方法是错误的。

相反,不要通过该计算,而是在合并方法中计算。我试着用下面的改变你的代码,它工作得很好。

merge(array, left, right); 
... 
private void merge(int[] array, int[] left, int[] right) { 
    int i=0,j=0,k=0; 
    int leftCount= left.length; 
    int rightCount = right.length; 
+0

谢谢@Jeyaprakash,完美的作品。我忽略了这一点 – ali