簡體   English   中英

Mergesort實施不正確

[英]Mergesort implementation not correct

我一直在嘗試編寫一個基本的自上而下的合並排序,但是在代碼完成執行之后,數組未完全排序。 我已經嘗試調試它,但是所有遞歸都很難確定。 我還嘗試將我的代碼與其他mergesort示例進行比較,但是我沒有運氣找到任何差異

    private void mergeSort(int[] arr) {
        int[] aux = new int[arr.length];
        sort(arr, aux, 0, arr.length - 1);
    }

    private void sort(int[] arr, int[] aux, int lo, int hi) {
        if(hi <= lo)
            return;
        int mid = lo + ((hi - lo) / 2);
        sort(arr, aux, lo, mid);
        sort(arr, aux, mid + 1, hi);
        merge(arr, aux, lo, mid, hi);
    }

    private void merge(int[] arr, int[] aux, int lo, int mid, int hi) {
        for(int i  = lo;i <= hi;i++)
            aux[i] = arr[i];

        int x = lo;
        int y = mid + 1;
        for(int i = lo; i <= hi; i++){
            if(x > mid)              arr[i] = aux[y++];
            else if(y > hi)          arr[i] = aux[x++];
            else if(aux[y] < aux[i]) arr[i] = aux[y++];
            else                     arr[i] = aux[x++];
        }
    }

更改

  else if(aux[y] < aux[i]) arr[i] = aux[y++];

  else if(aux[y] < aux[x]) arr[i] = aux[y++];

注意aux [ x ]

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM