首页 >Java >java教程 >如何在Java中高效地比较两个列表并找到共同和独特的元素?

如何在Java中高效地比较两个列表并找到共同和独特的元素?

DDD
DDD原创
2024-11-28 14:17:11776浏览

How Can I Efficiently Compare Two Lists in Java and Find Common and Unique Elements?

比较 Java 中的两个列表

您想要比较两组数据以确定它们共享多少个元素。假设这些不是 Java List 对象,请考虑以下方法:

使用 ArrayList

利用 ArrayList,您可以使用 keepAll 方法。此方法仅保留第一个列表中也存在于第二个列表中的元素。例如:

import java.util.Collection;
import java.util.ArrayList;
import java.util.Arrays;

public class ListComparison {
    public static void main(String[] args) {
        Collection<String> listOne = new ArrayList<>(Arrays.asList("milan", "dingo", "elpha", "hafil", "meat", "iga", "neeta.peeta"));
        Collection<String> listTwo = new ArrayList<>(Arrays.asList("hafil", "iga", "binga", "mike", "dingo"));

        listOne.retainAll(listTwo);
        System.out.println(listOne);
    }
}

此代码将打印 listOne 和 listTwo 之间公共元素的列表。

使用 HashSet

如果你想要要包含重复值(即在任一列表中多次出现的元素),您可以使用 HashSet 而不是数组列表。 HashSet不允许重复,因此比较后,可以使用removeAll方法从两个列表中的元素组合集中删除公共元素。这将为您提供一个独特的非常见元素列表:

import java.util.Collection;
import java.util.HashSet;
import java.util.Arrays;

public class ListComparison {
    public static void main(String[] args) {

        Collection<String> listOne = Arrays.asList("milan", "iga",
                "dingo", "iga",
                "elpha", "iga",
                "hafil", "iga",
                "meat", "iga",
                "neeta.peeta", "iga");

        Collection<String> listTwo = Arrays.asList("hafil",
                "iga",
                "binga",
                "mike",
                "dingo", "dingo", "dingo");

        Collection<String> similar = new HashSet<>(listOne);
        Collection<String> different = new HashSet<>();
        different.addAll(listOne);
        different.addAll(listTwo);

        similar.retainAll(listTwo);
        different.removeAll(similar);

        System.out.printf("One:%s%nTwo:%s%nSimilar:%s%nDifferent:%s%n", listOne, listTwo, similar, different);
    }
}

此修改后的代码将输出两个列表之间相似和不同的元素。

以上是如何在Java中高效地比较两个列表并找到共同和独特的元素?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn