java 判断两个List是否包含 判断两个list相等_list实体校验有两个相同的字符串-程序员宅基地

技术标签: java  

java 判断两个List是否包含 判断两个list相等
https://blog.51cto.com/u_12855/7333853

1、直接使用equals()比较

众所周知,两个列表具有完全相同的元素并且具有完全相同的顺序时,它们是相等的。因此, 如果我们业务要求两个list顺序一致,可以使用equals()方法进行相等性检查:

@Test
public void equalityCheckOfTwoLists() {
  
    List<Integer> list1 = Arrays.asList(1, 2, 3);
    List<Integer> list2 = Arrays.asList(1, 2, 3);
    List<Integer> list3 = Arrays.asList(2, 1, 3);
  
    assertTrue(list1.equals(list2));
    assertFalse(list1.equals(list3));
  
}

即使list1的和项目list3包含相同的元素{1,2,3},但是元素顺序不一样,所以list1和list3还是不相等的。

注意:
有的业务要求元素顺序不必要求一致 我们要做的就是检查两个列表是否包含相同的元素,而不管它们在列表中的顺序,那如何去实现呢?

2、将list排序之后再比较


处理逻辑主要有:
(1) 如果两个list都为null,则返回true
(2)如果一个list不为空 ,另外一个指向空值返回false
(3)两个list的size()不同 ,返回false。

public <T extends Comparable<T>> boolean isEquals(List<T> list1, List<T> list2){     
    if (list1 == null && list2 == null) {
        return true;
    }
    //Only one of them is null
    else if(list1 == null || list2 == null) {
        return false;
    }
    else if(list1.size() != list2.size()) {
        return false; 
    }
     
    //copying to avoid rearranging original lists
    list1 = new ArrayList<T>(list1); 
    list2 = new ArrayList<T>(list2);   
  
    Collections.sort(list1);
    Collections.sort(list2);      
     
    return list1.equals(list2);
}

请注意:
我们这里创建了两个列表的副本来保证原始列表中的元素保持不变。

3、使用Sets / contains()比较list


如果列表没有重复元素 ,我们可以使用list中创建TreeSet,然后使用equals()比较它们:

public <T extends Comparable<T>> boolean isEquals(List<T> list1, List<T> list2){     
    if (list1 == null && list2 == null) {
        return true;
    }
    //Only one of them is null
    else if(list1 == null || list2 == null) {
        return false;
    }
    else if(list1.size() != list2.size()) {
        return false; 
    }
  
    Set<T> set1 = new TreeSet<>(list1);
    Set<T> set2 = new TreeSet<>(list2);
     
    return set1.equals(set2);
}

我们可以更加简单使用contains()比较,不用创建 Sets:

return list1.containsAll(list2) && list2.containsAll(list1);

new HashSet<>(list1).containsAll(list2.get()) &&

new HashSet<>(list2.get()).containsAll(list1)) 

new HashSet<>(list1.get()).containsAll(list2.get()) &&

new HashSet<>(list2.get()).containsAll(list1.get()))     
             

但是这里要注意 如果我们list元素存在重复,使用contains()或者 Sets比较就会有问题。看下面这个案例你就知道怎么回事了。

List<Integer> list1 = Arrays.asList(1, 2, 3, 3);
List<Integer> list2 = Arrays.asList(3, 1, 2, 2);
  
// will return true, but actual value should be false
System.out.println(list1.isEquals(list2));

在上面的示例中,list1包含一个2和两个3,而list2包含两个2和一个3,我们可以看到两个list其实是不相等的,但是程序会错误地返回true。所以使用这个方法时要确保list元素没有重复的。

4、使用Apache Commons工具类


CollectionUtils提供了集合相等的判断工具方法isEqualCollection,只要我们确保两个集合非空可以直接使用该方法来判断集合相等。

List<Integer> list1 = Arrays.asList(1, 2, 3, 3);
List<Integer> list2 = Arrays.asList(3, 1, 3, 2);
  
System.out.println(CollectionUtils.isEqualCollection(list1, list2)); //true


5、结论


今天我们学习了检查Java中两个列表是否相等4种方法,一般默认情况下,当两个列表具有相同顺序的相同元素时,我们就知道它们是相等的。如果我们对元素的顺序不太关心的话,可以采用其它几种方法进行列表相等性比较。


java list containsAll效率


https://blog.51cto.com/u_16175440/6861303


在Java中,List是一种常用的数据结构,用于存储一组有序的元素。List提供了containsAll()方法用于判断一个List是否包含另一个List中的所有元素。然而,在某些情况下,containsAll()方法的效率可能会变得很低,本文将对其效率进行分析,并提供一些优化的方法。

containsAll()方法的使用

在使用containsAll()方法之前,让我们先了解一下它的用法。containsAll()方法接受一个Collection类型的参数,用于判断当前List是否包含该Collection中的所有元素。它返回一个布尔值,表示是否包含所有元素。

以下是一个示例代码:

List<Integer> list1 = new ArrayList<>();
list1.add(1);
list1.add(2);
list1.add(3);

List<Integer> list2 = new ArrayList<>();
list2.add(2);
list2.add(3);

boolean containsAll = list1.containsAll(list2);
System.out.println("List1 contains all elements of List2: " + containsAll); // 输出:true

在上述示例中,我们定义了两个List:list1和list2。list1包含了元素1、2和3,而list2只包含了元素2和3。通过调用list1.containsAll(list2)方法,我们可以判断list1是否包含list2中的所有元素。在本例中,list1确实包含list2中的所有元素,因此containsAll的返回值为true。

containsAll()方法的效率问题

尽管containsAll()方法非常方便,但它的效率并不总是很高。特别是当List中的元素数量较大时,containsAll()方法可能会引起性能问题。这是因为containsAll()方法的实现需要遍历两个List,并逐个比较元素是否相等。对于包含n个元素的List,这将导致O(n^2)的时间复杂度。

以下是一个包含大量元素的示例代码:

List<Integer> longList = new ArrayList<>();
for (int i = 0; i < 10000; i++) {
    longList.add(i);
}

List<Integer> subList = new ArrayList<>();
for (int i = 9990; i < 10000; i++) {
    subList.add(i);
}

boolean containsAll = longList.containsAll(subList);
System.out.println("Long list contains all elements of sub list: " + containsAll);

在上述示例中,我们创建了一个包含10000个元素的longList,并从中截取了最后10个元素构成subList。然后,我们使用containsAll()方法判断longList是否包含subList中的所有元素。由于longList的长度较大,containsAll()方法的执行时间可能会很长。

containsAll()方法的优化

为了提高containsAll()方法的效率,我们可以采取一些优化措施。以下是几种常见的优化方法:

使用Set代替List
由于List是有序的,containsAll()方法需要逐个比较元素的顺序和值。而Set是无序的,containsAll()方法可以通过哈希表等数据结构来快速判断是否包含所有元素。因此,如果不需要保持元素的顺序,可以考虑使用Set代替List来实现containsAll()方法。

Set<Integer> set1 = new HashSet<>(list1);
Set<Integer> set2 = new HashSet<>(list2);

boolean containsAll = set1.containsAll(set2);
System.out.println("Set1 contains all elements of Set2: " + containsAll);

通过将List转换为Set,我们可以利用Set的高效查找特性,从而提高containsAll()方法的效率。

优化equals()方法的复杂度
containsAll()方法的效率还受到元素的equals()方法实现复杂度的影响。如果元素的equals()方法的实现比较耗时,那么containsAll()方法的效率也会下降。因此,我们可以优化元素的equals()方法,以提高containsAll()方法的效率。

假设我们有一个自定义的元素类,其中equals()方法的实现如下:

登录后复制 
public class MyElement {
    private int value;
    
    // 构造函数、getter和
-----------------------------------

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/zhangshuzu/article/details/132899003

智能推荐

用python+graphviz/networkx画目录结构树状图_networkx画树状图-程序员宅基地

文章浏览阅读1.3w次,点赞2次,收藏22次。想着用python绘制某目录的树状图,一开始想到了用grapgviz,因为去年离职的时候整理文档,用graphviz画过代码调用结构图。graphviz有一门自己的语言DOT,dot很简单,加点加边设置属性就这点东西,而且有python接口。我在ubuntu下,先要安装graphviz软件,官网有deb包,然后python安装pygraphviz模块。目标功能是输入一个路径,输出该路径下的_networkx画树状图

【绿色求索T1设备资产通1.5单机版】适用于资产密集型企业管理_求索t1设备资产通系统(单机版)注册码-程序员宅基地

文章浏览阅读899次。绿色求索T1设备资产通 1.5 单机版 [企业管理高价值设备资产的使用情况]下载软件大小:5.56MB软件语言:简体中文软件类别:软件授权:免费软件更新时间:2013-08-03 07:44:00应用平台:Win2K,WinXP,Win2003,Vista,Win7绿色软件下么官方地址:系统之家官网求索T1设备资产通 1.5 单机版 _求索t1设备资产通系统(单机版)注册码

王桂林C语言从放弃到入门课程-程序员宅基地

文章浏览阅读195次。课程目标16天,每天6节课,每节40分钟课堂实录,带你征服C语言,让所有学过和没有学过C语言的人,或是正准备学习C语言的人,找到学习C语言的不二法门。适用人群所有学过和没有学过C语言的人,或是正准备学习C语言的人!

xml实体注入问题_xml注入 内容注入-程序员宅基地

文章浏览阅读618次。xml实体注入问题 https://www.owasp.org/index.php/XML_External_Entity_(XXE)_Prevention_Cheat_Sheet#SAXBuilder_xml注入 内容注入

CRM是否有效?可通过这些办法判断!_crm如何判断会员唯一性-程序员宅基地

文章浏览阅读204次。CRM就是关于客户与公司销售团队之间的客户关系管理,它是一个销售人员管理工具。作为一个工具型产品,CRM能减少更多的人为错误,提高工作效率,从而达到更好的营收。如果在使用CRM期间出现以下现象:不能从不同潜在客户来源中获取潜在客户,不能将潜在客户转化为销售订单,不能提供合适的销售渠道,不能提高销售人员的工作效率。说明你使用的CRM存在问题。如何判断CRM是否有效?为了检查CRM的有效性,销售人员可以对捕获到的潜在客户和具体需求进行跟踪。销售人员能够判断这个潜在客户是否值得做进一步的跟进,或者是否应该放_crm如何判断会员唯一性

数据库三大范式_怎么理解第三范式-程序员宅基地

文章浏览阅读617次,点赞2次,收藏3次。1.第一范式:强调的是列的原子性,即数据库表的每一列都是不可分割的原子数据项。2. 第二范式:要求实体的属性完全依赖于主关键字。所谓完全依赖是指不能存在仅依赖主关键字一部分的属性。3.第三范式:任何非主属性不依赖于其它非主属性。在实际的开发中需要考虑诸多问题,如:考虑商业化的需求和目标(成本,用户体验),数据库的性能更加重要在规范性能问题的时候,需要适当地考虑一下规范性有时候会故意给某些表增加一些冗余的字段(多表查询→单表查询)_怎么理解第三范式

随便推点

云上武功秘籍(三)华为云上部署金蝶EAS Cloud_云上部署含带宽-程序员宅基地

文章浏览阅读1k次。每天琐事缠身,查错、维护、开接口?——不,你可以更加富有创造力!假期千里迢迢飞回公司机房处理一个小故障?——不,你可以更加自由高效!如果这就是你的写照,那为什么不选择上云呢?如果要上云,那为什么不选择华为云呢?云上秘籍第三弹——超详细、超全面的金蝶EAS Cloud部署教程来啦!负载均衡?WEB安全?一篇文章全部搞定!最后,请大家相信我们华为云生态 ISV团队的诚意和实力,谢谢!_云上部署含带宽

京东OLAP实践之路-程序员宅基地

文章浏览阅读640次。导读:本文主要介绍京东在构建OLAP从无到有各环节考虑的重点,由需求场景出发,剖析当前存在的问题,并提供解决方案,最后介绍OLAP的发展过程。▌需求场景1. 京东数据入口① 业务数据:订单..._京东 风控flink实践之路

qt qml与c++_qt c++ qml-程序员宅基地

文章浏览阅读1.4k次,点赞3次,收藏17次。QMl是一种高效的开发UI 的语言。QML(Qt Meta-Object Language,Qt元对象语言)是一种声明式编程语言,并且它是Qt框架的一个组成部分。Action 对应QAction,提供能够绑定到导航和视图的抽象的用户界面动作。StackView 对应QStackedWidget,提供基于栈的层叠布局。TabView 对应QTabWidget,提供带有标签的基于栈的层叠布局。TabView 对应QTabWidget,提供带有标签的基于栈的层叠布局。_qt c++ qml

详述GPS原理及RTK技术应用_rtk与gps数据的融合过程-程序员宅基地

文章浏览阅读8.9k次,点赞12次,收藏100次。详述GPS原理及RTK技术应用,包括四大卫星定位系统,GPS系统组成:GPS空间部分、地面监控系统和GPS信号接收器(GPS卫星定位车载终端);GPS定位技术(WGS-84坐标系),GPS定位原理(绝对定位原理,相对定位原理,静态相对定位,动态相对定位);GPS实时动态定位技术RTK的工作原理以及基准站和流动站组成,GPS实时差分定位RTK技术的缺点,移动站的解算状态;GPS网络RTK技术(VRS系统)组成和原理,作业优势,还有GPS_NMEA 0183协议相关语句介绍。_rtk与gps数据的融合过程

CSS基础(超详解)-程序员宅基地

文章浏览阅读2.3w次,点赞103次,收藏800次。Css (层叠样式表)是种格式化网页的标准方式, 用于控制设置网页的样式,并且允许CSS样式信息与网页内容(由HTML语言定义)分离的一种技术。_css

Android 百度地图SDK 自动定位、标记定位_安卓开发地图获取定位-程序员宅基地

文章浏览阅读1.2w次,点赞98次,收藏201次。先看效果图,如果不是你想要的,也就不浪费你时间了,这样对大家都好。如果是你满意的那样,我们就可以开始写了,首先创建一个名为MapDemo的项目。打开AndroidManifest.xml,复制你的包名然后进入百度地图开放平台,没有注册的小伙伴先注册,已注册的就直接登录,登录进去之后找到控制台→我的应用→创建应用点击之后进入,填写相关资料输入了应用名称、选择了应用类型和启用的服务,输入了包名。还差开发版和发布版的SHA1了① 获取开发版SHA1鼠标点击右侧边栏的Gradle→ app→Ta_安卓开发地图获取定位