比较 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中文网其他相关文章!