数组的反转计数指示数组距排序的距离(或距离)如果数组已经排序,则反转计数为0如果数组按逆序排序,反转计数是最大值。

#include <iostream>
#include <cstdlib>
using namespace std;

int merge(int arr[],int temp[], int left, int mid, int right)
{
    int inv_count = 0;
    int i = left;
    int j = mid;
    int k = right;
    while((i <= mid-1) && (j <= right))
    {
        if(arr[i] <= arr[j])
        {
            temp[k++] = arr[i++];
        }
        else
        {
            temp[k++] = arr[j++];
            inv_count += (mid - i);
        }
    }
    while(i <= mid-1)
        temp[k++] = arr[i++];
    while(j <= right)
        temp[k++] = arr[j++];
    for(i = left; i <= right; i++)
        arr[i] = temp[i];
    return inv_count;
}

int _merge_sort(int arr[], int temp[], int left, int right)
{
    int mid, inv_count = 0;
    if(right > left)
    {
        mid = (right+left)/2;
        inv_count = _merge_sort(arr,temp,left,mid);
        inv_count += _merge_sort(arr,temp,mid+1,right);
        inv_count += merge(arr,temp,left,mid+1,right);
    }
    return inv_count;
 }

int merge_sort(int arr[], int array_size)
{
    int *temp = (int *)malloc(sizeof(int)*array_size);
    return (_merge_sort(arr,temp,0,array_size-1));
}

int main()
{
    int arr[]= {1, 25, 12, 56, 36, 3, 0, 10, 8, 7};
    for(int i = 0; i < 10; i++)
        cout<<arr[i]<<"\t";
    cout<<"\n";
    cout<<merge_sort(arr,10)<<"\n";
    for(int i = 0; i < 10; i++)
        cout<<arr[i]<<"\t";
    cout<<"\n";
    return 0;
}

给定数组的预期输出是27,但我得到6。加上我的原始数组数据被修改了(它没有被排序的值被更改)。

最佳答案

在函数合并中,需要将int k=right替换为int k=left。我认为这个数组的预期输出是27这里讨论了合并排序的各种实现implementing merge sort in C++

10-06 05:25
查看更多