2

我有一个任务是在java中实现类似3路mergeshort的东西。我将有一个整数数组作为输入,我必须执行以下操作:

在具有 3 路除法的数组中实现合并排序,并打印数组的 3 个排序分区。例如,如果我将以下数组作为输入,[9 23 10 90 70 10 3 23]则输出将首先是 3 个分区 sorted:[9 10 24] [70 90] [3 10 23]然后是最终数组 sorted [3 9 10 10 23 24 70 90]

这是我迄今为止实施的:

public static void mergesort(int[] data) {
    int elements = data.length - 1;
    int length1;
    int length2;
    int length3;

    if (elements % 3 == 0) {
        length1 = elements / 3;
        length2 = elements / 3;
        length3 = elements / 3;
    } else if (elements % 3 == 1) {
        length1 = (elements / 3) + 1;
        length2 = elements / 3;
        length3 = elements / 3;
    } else { //if (elements % 3 == 2)
        length1 = (elements / 3) + 1;
        length2 = elements / 3;
        length3 = (elements / 3) + 1;
    }

    Arrays.sort(data, 0, length1 - 1);
    Arrays.sort(data, length1, length1 + length2 - 1);
    Arrays.sort(data, length1 + length2, length1 + length2 + length3 - 1);

    merge(data, 0, length1, length1 + length2);
    merge(data, 0, length1 + length2, length1 + length2 + length3);
}

private static void merge(int[] data, int first, int n1, int n2) {
    int[] temp = new int[n1 + n2];
    int copied = 0;
    int copied1 = 0;
    int copied2 = 0;
    int i;

    while ((copied1 < n1) && (copied2 < n2)) {
        if (data[first + copied1] < data[first + n1 + copied2]) {
            temp[copied++] = data[first + (copied1++)];
        } else {
            temp[copied++] = data[first + n1 + (copied2++)];
        }
    }

    while (copied1 < n1) {
        temp[copied++] = data[first + (copied1++)];
    }
    while (copied2 < n2) {
        temp[copied++] = data[first + n1 + (copied2++)];
    }

    for (i = 0; i < n1 + n2; i++) {
        data[first + i] = temp[i];
    }
}

我所做的是首先根据情况将数组拆分为 3 部分,然后对数组的 3 部分进行排序,然后尝试合并前 2 部分,然后将合并的部分与最后一部分合并。

我已经为初学者实现了这两种方法,但首先我非常确信合并方法很糟糕而且是错误的,其次我相信我在这个问题上的方法有问题我觉得即使是合并排序方法也是错误的执行得非常好。

我想要的是关于我应该在这个问题上做什么以及我的实施完全错误的建议

4

1 回答 1

2
void merge(int arr1[], int arr2[])
{
  int p1 = 0;
  int p2 = 0;
  int arr3[] = new int[arr1.length + arr2.length];

  while(p1 < arr1.length && p2 < arr2.length)
  {
    if(arr1[p1] > arr2[p2])
    {
      arr3[p2] = arr2[p2];
      p2++;
    }
    else
    {
      arr3[p1] = arr1[p1];
      p1++;
    }
  }

  //Now just add the code for just concatenating any remaining elements in 
  // either arr1 or arr2
  //This will happen if the lengths of arr1 and arr2 differ 


}

这是合并两个数组的基本代码(未测试,可能会错过边界条件)。尝试将其合并到您的代码中。

于 2012-05-17T15:42:50.593 回答