如何在不使用 Set 的情况下有效地从数组中删除重复项
2022-08-31 15:48:29
我被要求编写自己的实现来删除数组中的重复值。这是我创造的。但是在对1,000,000个元素进行测试后,它花了很长时间才完成。我可以做些什么来改进我的算法或任何要删除的错误吗?
我需要编写自己的实现 - 不使用Set
,HashSet
等。或任何其他工具,如迭代器。只是一个用于删除重复项的数组。
public static int[] removeDuplicates(int[] arr) {
int end = arr.length;
for (int i = 0; i < end; i++) {
for (int j = i + 1; j < end; j++) {
if (arr[i] == arr[j]) {
int shiftLeft = j;
for (int k = j+1; k < end; k++, shiftLeft++) {
arr[shiftLeft] = arr[k];
}
end--;
j--;
}
}
}
int[] whitelist = new int[end];
for(int i = 0; i < end; i++){
whitelist[i] = arr[i];
}
return whitelist;
}