簡體   English   中英

如何計算和返回算法中的交換 - MergeSort 和 QuickSort?

[英]How to count and return swaps in algorithms - MergeSort and QuickSort?

我有這個快速排序的代碼

int sum = 0;
int partition(int *L, int left, int right) {
        int pivot = left;
        int p_val = L[pivot];
        while (left < right) {
            while (L[left] <= p_val)
                left++;
            while (L[right] > p_val)
                right--;
            if (left < right) {
                swap(&L[left], &L[right]);
                sum++;
                }
            }
        swap(&L[pivot], &L[right]);
        sum++;
        return right;
        }

    void quicksort(int *L, int start, int end) {
        if (start >= end)
            return;
        int splitPoint = partition(L, start, end);
        quicksort(L, start, splitPoint - 1);
        quicksort(L, splitPoint + 1, end);
        }

我認為它工作正常。 對於給定的數組{8,4,2,1} ,我知道已經進行了 3 次交換。 但是,我需要修改代碼,以便 function 返回交換次數。 這可能嗎?如果可以,怎么做? 請盡可能簡單地解釋,因為我是這方面的新手。 我需要對 mergeSort 做同樣的事情,但我仍然沒有找到不太復雜的工作代碼。 當我這樣做時,我會更新問題。 謝謝你。

您可以使用int指針作為partitionquicksort函數的參數:

int partition(int *num, int *L, int left, int right) {
    ...
    if (left < right) {
       swap(&L[left], &L[right]);
       (*num)++; // increment number of swap
       sum++;
       }
    }
    ...
    swap(&L[pivot], &L[right]);
    (*num)++;
    sum++;
    return right;
}

quicksort中:

void quicksort(int *num, int *L, int start, int end) {
  if (start >= end)
      return;
  int splitPoint = partition(num, L, start, end);
  quicksort(num, L, start, splitPoint - 1);
  quicksort(num, L, splitPoint + 1, end);
}

然后在主 function 中:

int main() 
{ 
    int arr[] = {8, 4, 2, 4, 5, 7, 8, 9, 1}; 
    int n = sizeof(arr)/sizeof(arr[0]); 
    int num = 0;
    quicksort(&num, arr, 0, n-1); 
    printf("sum = %d num = %d\n", sum, num);
    return 0; 
}

好的,現在我有這個:

int sum = 0;
int partition(int *L, int left, int right) {
    int pivot = left;
    int p_val = L[pivot];

    while (left < right) {
        while (L[left] <= p_val)
            left++;
        while (L[right] > p_val)
            right--;
        if (left < right) {
            swap(&L[left], &L[right]);
            sum++;
            }
        }
    swap(&L[pivot], &L[right]);
    sum++;
    return right;
    }

int quicksort(int *L, int start, int end) {
    if (start >= end)
        return;
    int splitPoint = partition(L, start, end);
    quicksort(L, start, splitPoint - 1);
    quicksort(L, splitPoint + 1, end);
    return sum;
    }

對於快速排序,這個:

int sumMerge = 0;
void merge(int arr[], int l, int m, int r) {
    int i, j, k;
    int n1 = m - l + 1;
    int n2 = r - m;

    int L[n1], R[n2];

    for (i = 0; i < n1; i++)
        L[i] = arr[l + i];
    for (j = 0; j < n2; j++)
        R[j] = arr[m + 1 + j];

    i = 0;
    j = 0;
    k = l;
    while (i < n1 && j < n2) {
        if (L[i] <= R[j]) {
            arr[k] = L[i];
            i++;
        }
        else {
            arr[k] = R[j];
            j++;
        }
        k++;
    }
    while (i < n1) {
        arr[k] = L[i];
        i++;
        k++;
    }
    while (j < n2) {
        arr[k] = R[j];
        j++;
        k++;
    }
}

int mergeSort(int arr[], int l, int r){
    if (l < r) {
        int m = l + (r - l) / 2;
        mergeSort(arr, l, m);
        mergeSort(arr, m + 1, r);
        merge(arr, l, m, r);


    }
return sumMerge;
}

對於合並排序。 這個對嗎? 我的意思是,如果我將sumMerge++放在代碼中的某個位置,可以嗎? 另外,代碼的哪一部分實際上交換了合並中的值? 在快速排序中,我認為這很明顯,無論哪里調用swap ,這就是我增加計數器的地方。 但是合並呢?

暫無
暫無

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

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