优秀的编程知识分享平台

网站首页 > 技术文章 正文

Java8两个List集合取交集、并集、差集、去重并集

nanyue 2025-01-13 16:34:42 技术文章 1 ℃

前置知识

  • Stream API:用于对集合元素进行各种操作,如过滤、映射、排序等。
  • Set:不包含重复元素的集合。
  • List:有序的元素集合,允许有重复元素。

示例代码

首先,我们创建两个List<String>类型的列表作为示例数据:

java

深色版本

1import java.util.*;
2import java.util.stream.Collectors;
3
4public class ListOperations {
5
6    public static void main(String[] args) {
7        List<String> list1 = Arrays.asList("apple", "banana", "cherry", "date");
8        List<String> list2 = Arrays.asList("banana", "date", "fig", "grape");
9
10        // 交集
11        List<String> intersection = findIntersection(list1, list2);
12        System.out.println("Intersection: " + intersection);
13
14        // 并集
15        List<String> union = findUnion(list1, list2);
16        System.out.println("Union: " + union);
17
18        // 差集 (list1 - list2)
19        List<String> difference = findDifference(list1, list2);
20        System.out.println("Difference (list1 - list2): " + difference);
21
22        // 去重后的并集
23        List<String> uniqueUnion = findUniqueUnion(list1, list2);
24        System.out.println("Unique Union: " + uniqueUnion);
25    }
26
27    private static List<String> findIntersection(List<String> list1, List<String> list2) {
28        Set<String> set1 = new HashSet<>(list1);
29        return list2.stream()
30                    .filter(set1::contains)
31                    .collect(Collectors.toList());
32    }
33
34    private static List<String> findUnion(List<String> list1, List<String> list2) {
35        Set<String> set1 = new HashSet<>(list1);
36        set1.addAll(list2);
37        return new ArrayList<>(set1);
38    }
39
40    private static List<String> findDifference(List<String> list1, List<String> list2) {
41        Set<String> set1 = new HashSet<>(list1);
42        set1.removeAll(new HashSet<>(list2));
43        return new ArrayList<>(set1);
44    }
45
46    private static List<String> findUniqueUnion(List<String> list1, List<String> list2) {
47        return Stream.concat(list1.stream(), list2.stream())
48                     .distinct()
49                     .collect(Collectors.toList());
50    }
51}

解释

  1. 交集 (findIntersection): 使用HashSet快速检查元素是否存在于另一个集合中。
  2. 并集 (findUnion): 将两个List转换为Set以自动去除重复元素,然后将它们合并。
  3. 差集 (findDifference): 从第一个集合中移除第二个集合中的所有元素。
  4. 去重后的并集 (findUniqueUnion): 将两个列表合并成一个流,使用distinct()方法去除重复项。

以上代码展示了如何用简洁的方式完成这些集合操作。你可以根据实际需求调整这些方法来满足你的业务逻辑。

Tags:

最近发表
标签列表