【发布时间】:2012-05-17 15:18:32
【问题描述】:
我有一个任务是在 java 中实现类似 3-way mergeshort 的东西。我将输入一个整数数组,我必须执行以下操作:
在具有 3 路除法的数组中实现合并排序,并打印数组的 3 个排序分区。例如,如果我将以下数组 [9 23 10 90 70 10 3 23] 作为输入,则输出将首先是排序的 3 个分区:[9 10 24][70 90][3 10 23],然后是排序的最终数组 [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 部分,然后将合并的部分与最后一部分合并.
我已经为初学者实现了这两种方法,但首先我非常确信合并方法很糟糕而且错误,其次我认为我在这个问题上的方法有问题我觉得即使是合并排序方法是错误的并且执行得非常糟糕。
我想要的是关于我应该在这个问题上做什么以及我的实施完全错误的建议
【问题讨论】:
-
您应该如何将数组除以 3?使用原始未排序数组或其他东西的索引?
-
不,没关系。您可以发布代码的输出/错误/异常吗?
-
我的代码实际上没有错误,只是我很确定它不起作用,但即使它起作用,这似乎也不是解决这个问题的正确方法,这就是为什么我我问我是否在这里做一些非常糟糕的事情,因为在我看来就是这样。顺便说一句,我还没有测试过数字,我只知道到目前为止我的代码没有错误
标签: java arrays merge mergesort