List 差集

文章目录

基本类型

ListUtils.subtract 方法用于计算两个集合的差集,即返回 list1 中有但 list2 中没有的元素。

其中,list1 指向第一个集合,list2 指向第二个集合。该方法返回一个新的 List 对象,它包含所有在 list1 中,但不在 list2 中的元素。

以下是使用 ListUtils.subtract 方法的示例代码:

java 复制代码
List<Integer> list1 = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> list2 = Arrays.asList(3, 4, 5, 6, 7);
List<Integer> diff = ListUtils.subtract(list1, list2);
System.out.println("List1: " + list1); // [1, 2, 3, 4, 5]
System.out.println("List2: " + list2); // [3, 4, 5, 6, 7]
System.out.println("Diff: " + diff);   // [1, 2]

在上面的示例中,我们使用 ListUtils.subtract 方法计算了两个整数列表的差集。具体来说,我们创建了两个列表 list1list2,它们有一些相同的元素(即3、4和5)。然后,我们使用 ListUtils.subtract 方法计算 list1list2 的差集,并将结果存储在 diff 变量中。输出结果表明,diff 中包含了 list1 中有但 list2 中没有的元素 1 和 2。

需要注意的是,ListUtils.subtract 方法返回的是一个新的 List 对象,并不会修改原始的列表。

对象类型

java 复制代码
public class MyClass {
    private String name;
    private int value;

    // 省略构造方法和其他方法

    // 省略getter和setter方法
}

// 创建包含自定义对象的列表
List<MyClass> list1 = new ArrayList<>();
list1.add(new MyClass("A", 1));
list1.add(new MyClass("B", 2));
list1.add(new MyClass("C", 3));

List<MyClass> list2 = new ArrayList<>();
list2.add(new MyClass("B", 2));
list2.add(new MyClass("C", 3));
list2.add(new MyClass("D", 4));

// [{"name":"A","value":1}]
List<MyClass> diff1 = ListUtils.subtract(list1, list2);
// [{"name":"D","value":4}]
List<MyClass> diff2 = ListUtils.subtract(list2, list1);

在这个示例中,我们有两个包含自定义对象 MyClass 的列表 list1list2。我们使用 ListUtils.subtract 方法计算了这两个列表的差集,并将结果存储在 diff 变量中。最终得到的 diff 列表包含了 list1 中有但 list2 中没有的元素。

需要注意的是,为了使 ListUtils.subtract 方法正常工作,MyClass 类需要正确实现 equalshashCode 方法,以便进行对象的比较和判断。

相关推荐
Darling噜啦啦4 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
qq_369224335 天前
Windows全系通用!ntdll.dll文件丢失、报错、闪退问题的完整排查与修复教程
windows·dll·dll修复·dll丢失·dll错误
小小工匠5 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾5 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8215 天前
算法复键——树状数组
数据结构·算法
阿米亚波5 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
caimouse5 天前
Reactos 第 10 章 网络操作 — 10.3.1 NIC驱动
网络·windows
牛油果子哥q5 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
初圣魔门首席弟子5 天前
Node.js 详细介绍(知识库版)
windows·qt·node.js·知识库
凌波粒5 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode