有什么方法可以这样做吗?我正在寻找,但找不到任何。

另一个问题:我需要这些方法来过滤文件。
有些是 AND 过滤器,有些是 OR 过滤器(就像集合论中的一样),所以我需要根据所有文件和保存这些文件的联合/相交 ArrayLists 进行过滤。

我应该使用不同的数据结构来保存文件吗?还有什么可以提供更好的运行时间吗?

最佳答案

这是一个不使用任何第三方库的简单实现。与 retainAllremoveAlladdAll 相比的主要优势在于,这些方法不会修改方法的原始列表输入。

public class Test {

    public static void main(String... args) throws Exception {

        List<String> list1 = new ArrayList<String>(Arrays.asList("A", "B", "C"));
        List<String> list2 = new ArrayList<String>(Arrays.asList("B", "C", "D", "E", "F"));

        System.out.println(new Test().intersection(list1, list2));
        System.out.println(new Test().union(list1, list2));
    }

    public <T> List<T> union(List<T> list1, List<T> list2) {
        Set<T> set = new HashSet<T>();

        set.addAll(list1);
        set.addAll(list2);

        return new ArrayList<T>(set);
    }

    public <T> List<T> intersection(List<T> list1, List<T> list2) {
        List<T> list = new ArrayList<T>();

        for (T t : list1) {
            if(list2.contains(t)) {
                list.add(t);
            }
        }

        return list;
    }
}

关于java - Java 中 ArrayList 的交集和并集,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/5283047/

10-12 20:58