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

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

java 复制代码
package com.example.demo;

import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.Stream;

/**
 * Test 测试
 *
 * @author Administrator
 * @version 2024/08/19 13:39
 **/
public class Test {
    public static void main(String[] args) {
        List<String> list1 = Arrays.asList("apple", "banana", "cherry", "date");
        List<String> list2 = Arrays.asList("banana", "date", "fig", "grape");

        // 交集
        List<String> intersection = findIntersection(list1, list2);
        System.out.println("Intersection: " + intersection);

        // 并集
        List<String> union = findUnion(list1, list2);
        System.out.println("Union: " + union);

        // 差集 (list1 - list2)
        List<String> difference = findDifference(list1, list2);
        System.out.println("Difference (list1 - list2): " + difference);

        // 去重后的并集
        List<String> uniqueUnion = findUniqueUnion(list1, list2);
        System.out.println("Unique Union: " + uniqueUnion);
    }

    private static List<String> findIntersection(List<String> list1, List<String> list2) {
        Set<String> set1 = new HashSet<>(list1);
        return list2.stream()
                .filter(set1::contains)
                .collect(Collectors.toList());
    }

    private static List<String> findUnion(List<String> list1, List<String> list2) {
        Set<String> set1 = new HashSet<>(list1);
        set1.addAll(list2);
        return new ArrayList<>(set1);
    }

    private static List<String> findDifference(List<String> list1, List<String> list2) {
        Set<String> set1 = new HashSet<>(list1);
        set1.removeAll(new HashSet<>(list2));
        return new ArrayList<>(set1);
    }

    private static List<String> findUniqueUnion(List<String> list1, List<String> list2) {
        return Stream.concat(list1.stream(), list2.stream())
                .distinct()
                .collect(Collectors.toList());
    }
}

交集 (findIntersection): 使用HashSet快速检查元素是否存在于另一个集合中。

并集 (findUnion): 将两个List转换为Set以自动去除重复元素,然后将它们合并。

差集 (findDifference): 从第一个集合中移除第二个集合中的所有元素。

去重后的并集 (findUniqueUnion): 将两个列表合并成一个流,使用distinct()方法去除重复项。

相关推荐
v***59832 小时前
DeepSeek API 调用 - Spring Boot 实现
windows·spring boot·后端
无限进步_2 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
Swift社区3 小时前
LeetCode 432 - 全 O(1) 的数据结构
数据结构·算法·leetcode
芬加达3 小时前
leetcode34
java·数据结构·算法
q***2514 小时前
Windows操作系统部署Tomcat详细讲解
java·windows·tomcat
leoufung4 小时前
链表题目讲解 —— 删除链表的倒数第 n 个节点(LeetCode 19)
数据结构·leetcode·链表
dragoooon344 小时前
[优选算法专题八.分治-归并 ——NO.46~48 归并排序 、数组中的逆序对、计算右侧小于当前元素的个数]
数据结构·算法·排序算法·分治
招摇的一半月亮4 小时前
P2242 公路维修问题
数据结构·c++·算法
JHC0000004 小时前
交换链表中的节点
数据结构·链表