Java使用不同方式获取两个集合List的交集、补集、并集(相加)、差集(相减)
1 明确概念
首先知道几个单词的意思:
并集 = union
交集 = intersection
补集 = complement
析取 = disjunction
减去 = subtract
1.1 并集
对于两个给定集合A、B,由两个集合所有元素构成的集合,叫做A和B的并集。
记作:AUB 读作“A并B”
例:{3,5}U{2,3,4,6}= {2,3,4,5,6}
1.2 交集
对于两个给定集合A、B,由属于A又属于B的所有元素构成的集合,叫做A和B的交集。
记作: A∩B 读作“A交B”
例:A={1,2,3,4,5},B={3,4,5,6,8},A∩B={3,4,5}
1.3 补集
一般地,设S是一个集合,A是S的一个子集,由S中所有不属于A的元素组成的集合,叫做子集A在S中的绝对补集。
记作:∁UA,包括三层含义:
1)A是U的一个子集,即A⊊U;
2)∁UA表示一个集合,且∁UA⊊U;
3)∁UA是由U中所有不属于A的元素组成的集合,∁UA与A没有公共元素,U中的元素分布在这两个集合中。
2 使用apache工具包
2.1 导入依赖
<!-- apache 集合工具类 --><dependency><groupId>org.apache.commons</groupId><artifactId>commons-collections4</artifactId><version>4.1</version></dependency>
2.2 代码如下:
public static final List<String> list1 = Arrays.asList("A", "B", "C", "D", "E", "F", null);public static final List<String> list2 = Arrays.asList("1", "2", "3", "D", "E", "F", null);/*** apache测试方法*/@Testpublic void apacheTest() {System.out.println("交集:" + CollectionUtils.intersection(list1, list2)); // 交集System.out.println("补集:" + CollectionUtils.disjunction(list1, list2)); // 补集System.out.println("并集:" + CollectionUtils.union(list1, list2)); // 并集System.out.println("list1的差集:" + CollectionUtils.subtract(list1, list2)); // list1的差集System.out.println("list2的差集:" + CollectionUtils.subtract(list2, list1)); // list2的差集}
输出:
3 使用hutool工具包
3.1 导入依赖
<!-- hutool工具类 --><dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.12</version></dependency>
3.2 代码如下:
public static final List<String> list1 = Arrays.asList("A", "B", "C", "D", "E", "F", null);public static final List<String> list2 = Arrays.asList("1", "2", "3", "D", "E", "F", null);/*** hutool工具类*/@Testpublic void hutoolTest() {System.out.println("交集:" + CollectionUtil.intersection(list1, list2)); // 交集System.out.println("补集:" + CollectionUtil.disjunction(list1, list2)); // 补集System.out.println("并集:" + CollectionUtil.union(list1, list2)); //并集System.out.println("list1的差集"+CollectionUtil.subtract(list1,list2));System.out.println("list2的差集"+CollectionUtil.subtract(list2,list1));System.out.println("list1的差集:" + CollectionUtil.subtractToList(list1, list2));System.out.println("list2的差集:" + CollectionUtil.subtractToList(list2, list1));}
输出:
3.3 注意
subtract()和subtractToList()作用一样,不过处理方式不同,使用subtract()时,参数不能是Arrays.asList()的结果,否则会报异常,因为Arrays.asList()返回的对象是Arrays.ArrayList,在方法实现里面调用的是AbstractList抽象类里面的removeAll()方法,该方法代码如下:
public abstract class AbstractList<E> extends AbstractCollection<E> implements List<E> {// ....public E remove(int index) {throw new UnsupportedOperationException();}// ....
}
4 使用stream方式
4.1 代码如下:
public static final List<String> list1 = Arrays.asList("A", "B", "C", "D", "E", "F", null);public static final List<String> list2 = Arrays.asList("1", "2", "3", "D", "E", "F", null);/*** stream方式*/@Testpublic void streamTest() {List<Object> intersection = list1.stream().filter(list2::contains).collect(Collectors.toList());System.out.println("交集:" + intersection);List<String> subtract1 = list1.stream().filter(s -> !list2.contains(s)).collect(Collectors.toList());System.out.println("集合list1的差集:" + subtract1);List<String> subtract2 = list2.stream().filter(s -> !list1.contains(s)).collect(Collectors.toList());System.out.println("集合list2的差集:" + subtract2);List<String> union1 = list1.parallelStream().collect(Collectors.toList());List<String> union2 = list2.parallelStream().collect(Collectors.toList());union1.addAll(union2);List<String> union3 = union1.stream().distinct().collect(Collectors.toList());System.out.println("并集:" + union3);}
输出:
5 使用Collection接口中的方法
5.1 代码如下:
public static String[] attr1 = new String[]{"A", "B", "C", "D", "E", "F", null};public static String[] attr2 = new String[]{"1", "2", "3", "D", "E", "F", null};/*** 使用Collection接口中的方法*/@Testpublic void collectionTest() {List<String> list1 = new ArrayList<>(Arrays.asList(attr1));List<String> list2 = new ArrayList<>(Arrays.asList(attr2));list1.retainAll(list2);System.out.println("交集:" + list1);ArrayList<String> list3 = new ArrayList<>(Arrays.asList(attr1));ArrayList<String> list4 = new ArrayList<>(Arrays.asList(attr2));Set<Object> set = new HashSet<>();set.addAll(list3);set.addAll(list4);System.out.println("并集:" + set);ArrayList<String> list5 = new ArrayList<>(Arrays.asList(attr1));ArrayList<String> list6 = new ArrayList<>(Arrays.asList(attr2));list5.removeAll(list6);System.out.println("集合A的差集:" + list5);ArrayList<String> list7 = new ArrayList<>(Arrays.asList(attr1));ArrayList<String> list8 = new ArrayList<>(Arrays.asList(attr2));list8.removeAll(list7);System.out.println("集合B的差集:" + list8);}
输出:
相关文章:
Java使用不同方式获取两个集合List的交集、补集、并集(相加)、差集(相减)
1 明确概念首先知道几个单词的意思:并集 union交集 intersection补集 complement析取 disjunction减去 subtract1.1 并集对于两个给定集合A、B,由两个集合所有元素构成的集合,叫做A和B的并集。记作:AUB 读作“A并B”例&#…...
【Android笔记80】Android之Retrofit适配器和文件上传下载
这篇文章,主要介绍Android之Retrofit适配器和文件上传下载。 目录 一、Retrofit适配器 1.1、Retrofit适配器 (1)引入RxJava依赖 (2)定义接口...
Nodejs模块化
1.模块化 1.1.模块化的基本概念 模块化是指解决一个复杂问题时,自顶向下逐层把系统划分为若干模块的过程。对于整个系统而言,模块是可组合、分解和更换的单元。 1.2 编程中的模块化 编程领域的模块化就是把一个大文件拆成独立并相互依赖的多个小模块…...
C++STL基础
STL基础 诞生 cpp的面向对象和泛型编程的思想本质就是提高复用性诞生了STL库 基本概念 STL标准模板库STL从广义上分为容器、算法及迭代器容器和算法之间通过迭代器进行连接STL几乎所有的代码都采用了模板类或者模板函数 基本组件 容器、算法、迭代器、仿函数、适配器、空间配置…...
数学建模经验【更新中】
数学建模简单入门 一、 分工 3人,1人论文,1人代码主力,1人论文代码(前一半时间主代码,后一半时间主论文) Tips: 不养闲人,论文必须要在对代码和题目极其了解并且能跟上队友思路的情况下才能写…...
【python学习笔记】:Excel 数据的封装函数
对比其它编程语言,我们都知道Python最大的优势是代码简单,有丰富的第三方开源库供开发者使用。伴随着近几年数据分析的热度,Python也成为最受欢迎的编程语言之一。而对于数据的读取和存储,对于普通人来讲,除了数据库之…...
如何获取或设置CANoe以太网网卡信息(GET篇)
CAPL提供了一系列函数用来操作CANoe网卡。但是,但是,首先需要明确一点,不管是获取网卡信息,还是设置网卡信息,只能访问CAPL程序所在的节点下的网卡,而不是节点所在的以太网通道下的所有网卡 关于第一张图中,Class节点下,有三个网卡:Ethernet1、VLAN 1.100、VLAN 1.200…...
“终于我从字节离职了...“一个年薪50W的测试工程师的自白...
我递上了我的辞职信,不是因为公司给的不多,也不是因为公司待我不好,但是我觉得,我每天看中我憔悴的面容,每天晚上拖着疲惫的身体躺在床上,我都不知道人生的意义,是赚钱吗?是为了更好…...
【Spring】八种常见Bean加载方式
🚩本文已收录至专栏:Spring家族学习 一.引入 (1) 概述 关于bean的加载方式,spring提供了各种各样的形式。因为spring管理bean整体上来说就是由spring维护对象的生命周期,所以bean的加载可以从大的方面划分成2种形式ÿ…...
第五回:样式色彩秀芳华
import matplotlib as mpl import matplotlib.pyplot as plt import numpy as np第五回详细介绍matplotlib中样式和颜色的使用,绘图样式和颜色是丰富可视化图表的重要手段,因此熟练掌握本章可以让可视化图表变得更美观,突出重点和凸显艺术性。…...
关于@Test单元测试
1、关于doReturndoReturn(new Test()).when(testService).updateStatusByLock(any(), any());在单元测试里这个方法可以执行到这里之间跳过不去执行,返回你想要的返回值2、关于givengiven(user.getName(any())).willReturn("张三");在单元测试里这个方法 …...
【项目实战】WebFlux整合r2dbc-mysql实战
一、背景 Webflux虽然是响应式的,但是没办法,JDBC是基于阻塞IO实现的,所以无法真正的威力发挥不出来。 但是,Webflux一旦整合了R2DBC之后,那么它将不再受限于数据库连接了,真正打通了响应式应用的任督二脉,性能才被释放。 当然,除了Spring推出的R2DBC协议,还有Orac…...
go版本分布式锁redsync使用教程
redsync使用教程前言redsync结构Pool结构Mutex结构acquire加锁操作release解锁操作redsync包的使用前言 在编程语言中锁可以理解为一个变量,该变量在同一时刻只能有一个线程拥有,以便保护共享数据在同一时刻只有一个线程去操作。对于高可用的分布式锁应…...
大数据之Hudi数据湖_大数据治理_简介_发展历史_特性_应用场景---大数据之Hudi数据湖工作笔记0001
支持hive spark flink 美国公司开发的~ 都在使用,这些企业都在用 支持hadoop的,更新,插入,删除 和数据增量处理 支持流式数据处理. hive是离线数仓 hive不支持事物 insert overwrite 底层后来通过这种方式支持了事物 insert overwrite处理数据很低效,因为更新是基于覆盖实现…...
射频功率放大器基于纵向导波的杆状构件腐蚀诊断方法的研究
实验名称:基于纵向导波的杆状构件腐蚀诊断方法研究方向:无损探伤测试设备:信号号发生器、安泰ATA-8202功率放大器、数据采集卡、直流电源、超声探头、钢杆、前置放大器。实验过程:图:试验装置试验装置如图3.2所示。监测…...
Leedcode 二分查找 理解1
一个up的理解 一、二分查找基础例题 力扣https://leetcode.cn/problems/binary-search/ 二、二分查找模板问题 带搜索区间分为3个部分: 1、[mid],直接返回 2、[left,mid-1],设置边界right mid - 1 3、[mid1,right]&#x…...
【告别篇】大家好,再见了,我转行了,在筹备创业
前言 相信大家也一直看到我的博客没有更新过了,我其实很久没有打开过博客了,也就意味着我很长一段时间都在停滞不前,没有了学习的动力。 现在我上来是想跟大家告个别 : 很多粉丝宝宝的私信我看了,但是没有回…...
Java——岛屿数量
题目链接 leetcode在线oj题——岛屿数量 题目描述 给你一个由 ‘1’(陆地)和 ‘0’(水)组成的的二维网格,请你计算网格中岛屿的数量。 岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相…...
《代码整洁之道》笔记
1章:专业人士要有专业人士素养,要有责任心,编写代码尽可能完善没有bug,有bug也要勇于承担。坚持学习,坚持练习,保证自己的专业技能。谦虚,相互学习,与顾客达成一致2章:说…...
个人网站如何集成QQ快捷登录功能?
目录 一、网站集成QQ快捷登录的好处 二、网站接入QQ快捷登录具体步骤 (1)登录到QQ互联官网 (2)进行个人开发者认证 (3)创建网站应用 (4)填写网站资料 三、如何在本地开发环境…...
从工厂打螺丝到月薪18k测试工程师,我该满足吗?
以前我比较喜欢小米那句“永远相信美好的事情即将发生”,后来发现如果不努力不可能有美好的事情发生!01高中毕业进厂5年,创业经商多次战败,为了生计辗转奔波高中毕业后我就进了工厂,第一份工作是做模具加工。从500元一…...
【相关分析-高阶绘图】MATLAB实现皮尔逊相关分析-散点直方图
虽然皮尔逊相关分析很常见,但如何更好的展现相关性、散点分布、柱状分布,以提升研究结果的美感和冲击感呢?本文拟通过MATLAB绘制包含散点分布、柱状分布、线性展示的散点直方图,有助于审稿人眼前一亮。 1、Pearson相关系数原理 Pearson相关系数(Pearson Correlation Co…...
Spark性能优化二 Shuffle机制分析
(一) 什么情况下发生shuffle 在MapReduce框架中,Shuffle是连接Map和Reduce之间的桥梁,Map阶段通过shuffle读取数据并输出到对应的Reduce;而Reduce阶段负责从Map端拉取数据并进行计算。在整个shuffle过程中,…...
软测入门(四)Appium-APP移动测试基础
Appium 用来测试手机程序。 测试方面: 功能测试安装卸载测试升级测试兼容测试 Android系统版本不同分辨率不同网络 网络切换、中断测试使用中来电话、短信横竖屏切换 环境搭建 Java安装(查资料)Android SDK安装,配置 HOME和P…...
华为OD机试用Python实现 -【集五福】 |老题且简单
华为OD机试题 最近更新的博客华为 OD 机试 300 题大纲集五福题目描述输入描述输出描述示例一输入输出示例二输入输出代码编写思路Python 代码最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典...
Typro使用以及安装教程来啦
Typora是一款轻便简洁的Markdown编辑器,支持即时渲染技术,这也是与其他Markdown编辑器最显著的区别。即时渲染使得你写Markdown就想是写Word文档一样流畅自如,不像其他编辑器的有编辑栏和显示栏。今天为大家分享下有关Typroa的安装以及使用&a…...
武汉凯迪正大KD305系列智能数字绝缘电阻测试仪
一、概述 KD305系列智能数字绝缘电阻测试仪采用嵌入式工业单片机实时操作系统,数字模拟指针与数字段码显示结合,该系列表具有多种电压输出等级(500V、1000V、2500V、5000V、10000V)、容量大、抗干扰强、模拟指针与数字同步显示、交…...
如何使用码匠连接 Redis
目录 在码匠中集成 Redis 在码匠中使用 Redis 关于码匠 Redis 是由 Salvatore Sanfilippo 用 C 语言开发的一款开源的、高性能的键值对存储数据库,它采用 BSD 协议,为了适应不同场景下的存储需求,提供了多种键值数据类型。到目前为止&…...
防止网络攻击的10大网络安全措施
网络攻击每天都在发生。事实上,每天有超2000次的攻击是针对连接了互联网且未受保护的系统,大概每39s就会发生一次。网络攻击导致的数据泄露、敏感信息被盗、财务损失、声誉受损都给企业及个人带来威胁。随着各大企业对数字系统的依赖,网络威胁已成为当下面临的主要挑战。 实…...
LeetCode 面试题 05.02. 二进制数转字符串
【LetMeFly】面试题 05.02.二进制数转字符串 力扣题目链接:https://leetcode.cn/problems/bianry-number-to-string-lcci/ 二进制数转字符串。给定一个介于0和1之间的实数(如0.72),类型为double,打印它的二进制表达式…...
广东建设局网站/百度推广按点击收费
5.9.6. Usage Patterns 5.9.6.使用方式 模式可以以多种方式组织数据。一个安全的模式使用方式可以防止用户改变其他用户的查询行为。如果数据库中未使用安全的模式方式,那么在查询之前,需要进行保护性的设置。一般,需要在开始会话之前首先设…...
wordpress无法正常加载/公众号关键词排名优化
虽然这是一个操作系统的用来避免死锁的算法,其实完全可以把它当做一道ACM题来做。寻找安全序列上面我使用了回溯算法,条例还算清晰,发上来和大家共享同时备忘。 #include<iostream> using namespace std; #include<fstream> #inc…...
注册公司网站模板下载/深圳短视频seo教程
后端(路由)主要是获取客户端发来的请求(request),然后给他response。 //本地访问地址,http://127.0.0.1:8085/test.txt?namezhang&age27#li nodejs自带URL模块 var urlrequire(url) http.createServer…...
网站的好坏/辽宁和生活app下载安装
来源:量子位 作者:羿阁 萧箫 以“天才少年”身份加入华为的稚晖君,被曝已经离职,将开启创业! 虽然本人还没公开确认这一消息,但据华为员工爆料,目前华为内部已经搜不到对应的工号。 要知道&a…...
网站首页图片轮转代码 很好用/网站快速建站
PMBOK(2004 3rd 英)P28中介绍了几种组织结够,包括职能型(Functional) ,矩阵型(Matrix)和项目型(Projectized) 。其中矩阵型又分为Weak Matrix,Balanced Matrix和Strong Matrix. 书中只是从项目经理职权的角度比较了这几种组织结构的不同。下面是一些补充…...
wordpress快速建站/企业网站制作开发
适用系统:PC(后台回复「243」获取)大概有很多人会和学霸君一样,在一些需要注册的网站上都会使用同一个密码,例如各种论坛,视频网站等等。因为这样会方便记忆,但是有一种情况你们想过没有?如果你某一个网站的…...