10

可能重复:
从数组中删除元素(Java)

例如,如何删除特定的字符串数组值

String[] str_array = {"item1","item2","item3"};

我想从 str_array 中删除“item2”请帮助我我想要像这样的输出

String[] str_array = {"item1","item3"};

4

4 回答 4

37

我会这样做:

String[] str_array = {"item1","item2","item3"};
List<String> list = new ArrayList<String>(Arrays.asList(str_array));
list.remove("item2");
str_array = list.toArray(new String[0]);
于 2012-10-10T05:13:44.657 回答
11

您可以使用ArrayUtils API 将其删除。

array = ArrayUtils.removeElement(array, element);
于 2012-10-10T05:27:07.563 回答
7

如果必须使用数组,System.arraycopy是最高效、可扩展的解决方案。但是,如果必须多次从数组中删除一个元素,则应使用 List 的实现而不是数组。

以下利用System.arraycopy以达到预期的效果。

public static Object[] remove(Object[] array, Object element) {
    if (array.length > 0) {
        int index = -1;
        for (int i = 0; i < array.length; i++) {
            if (array[i].equals(element)) {
                index = i;
                break;
            }
        }
        if (index >= 0) {
            Object[] copy = (Object[]) Array.newInstance(array.getClass()
                    .getComponentType(), array.length - 1);
            if (copy.length > 0) {
                System.arraycopy(array, 0, copy, 0, index);
                System.arraycopy(array, index + 1, copy, index, copy.length - index);
            }
            return copy;
        }
    }
    return array;
}

此外,如果您知道数组仅包含Comparable对象,则可以提高方法的效率。您可以Arrays.sort在将它们传递给remove方法之前对它们进行排序,修改为用于Arrays.binarySearch查找索引而不是 for 循环,从而将方法的这部分效率从 O(n) 提高到 O(nlogn)。

于 2012-10-10T05:41:24.350 回答
4

其他选项是将数组复制到其他数组接受而不是删除项目。

 public static String[] removeItemFromArray(String[] input, String item) {
    if (input == null) {
        return null;
    } else if (input.length <= 0) {
        return input;
    } else {
        String[] output = new String[input.length - 1];
        int count = 0;
        for (String i : input) {
            if (!i.equals(item)) {
                output[count++] = i;
            }
        }
        return output;
    }
}
于 2012-10-10T05:28:20.687 回答