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

智能推荐

迈开电子舞步:从Disco到House_disco和house-程序员宅基地

文章浏览阅读1.8k次。出现在70年代的Disco是当时主流的舞曲音乐,B.P.M(bits per minute)约在120拍左右。Disco舞曲本身节奏简单强劲,活泼轻松的旋律和编曲中的弦乐也容易被人接受,它在全世界范围内的风行应归功于当时的电影音乐:70年代的电影中大量使用了Disco舞曲。 Disco的风靡全球也带来了时尚的迅速更迭,与其相关的舞蹈及服饰文化也逐渐攀上潮流的浪尖。2.High-energy 由Di_disco和house

中国的铁路订票系统在世界上属于什么水平?-程序员宅基地

文章浏览阅读227次。????????关注后回复“进群”,拉你进程序员交流群????????来自公众号:沉默王二综合自知乎:https://www.zhihu.com/question/315887668大家好,今天分享的这篇:“中国的铁路订票系统在世界上属于什么水平?”我们来看看知友们都是如何评价我国铁路订票系统的——也就是大名鼎鼎的 12306。会非常有意思。先来看看这个 1.8 万赞的,我觉得说得非常有道理..._目前国内外对火车票订票系统设计研究水平

图的邻接矩阵和邻接表表示_udg 邻接表-程序员宅基地

文章浏览阅读701次。1.邻接矩阵用矩阵表示顶点与顶点间边的关系(是否有边)#define INFINITY INT_MAX#define MAX_VERTEX_NUM 20typdef enum{DG,DN,UDG,UDN}GraphKind;typedef struct{VertexType vexs[MAX_VERTEX_NUM];int arcs[MXA_VERTEX_NUM ] [MAX_VERTEX_NUM];int vexnum,arcnum;GraphKind kind;}MGraph;2_udg 邻接表

一步一步教你如何在AndroidStudio查看Android源码(AOSP源码)_如何用android studio 查看android源码-程序员宅基地

文章浏览阅读4.1w次,点赞10次,收藏56次。一步一步教你如何在AndroidStudio查看Android源码(AOSP源码)_如何用android studio 查看android源码

curl多线程下载类-程序员宅基地

文章浏览阅读250次。<?php /** * curl多线程下载类 */class MultiHttpRequest{ public $urls = array (); private $res = array (); private $curlopt_header = 0; private $method = "GET"; private $curlopt = array (); ..._curl 多线程下载

51单片机AD转换_单片机ad转换原理-程序员宅基地

文章浏览阅读1.9w次,点赞21次,收藏180次。51单片机AD转换电路设计实现关于AD转换的原理,大家在《数字电子技术》中已经学过,这里做过多的介绍,本文介绍一款经典的8位AD转换芯片ADC0804,基于51单片机设计AD转换电路,并完成测量值的转换。1 芯片引脚介绍CS:片选信号,低电平有效,即CS=0时候芯片才能正常工作,单独一个ADC0804芯片时候直接置零。当有多个芯片时候可以通过片选信号实现分时复用。WR:低电平有效,当WR信号由高到低时候实现一次ADC转换。RD:低电平有效,RD=0时候可以读取数据。Vin+:模拟电压输入端。_单片机ad转换原理

随便推点

【HTML/CSS/JavaScript-编程指南】-程序员宅基地

文章浏览阅读676次,点赞8次,收藏10次。学习网站:https://www.runoob.com/html/html-tutorial.html。

在职高学C语言程序设计,行动导向教学在高职《C语言程序设计》中的应用初探...-程序员宅基地

文章浏览阅读109次。行动导 向教学在高职 《语言程序设计》中的应用初探袁开友 姚骏屏(重庆正大软件职业技术学院 )摘 要 高等职业教育强调培 养 高技能型人 才, 语 言 导学 习”再到 “自主学 习完 成任务”的转变 。充分体现 了 “以程序 设 计 》是 计 算机 、软件 开发 等 专业 的 高职 学生 的技 能基 学生 为主体 ,以学 生为 中心 ”的原则,可有 效地 提高学生 的动础 ,在 本课教 学 实践 ..._程序设计 行动导向

数学建模-二胎政策对中国人口的影响-程序员宅基地

文章浏览阅读1.3k次。数学建模-二胎政策对中国人口的影响 研一的数学建模课上的关于“二胎政策对中国人口的影响”。研究中国人口,发现中国人口老龄化非常严重,如今假设不放开全面二胎,那么中国的未来真的非常令人堪忧。事实上,如今的单独二胎对人口的影响不是太多,每年添加100多万的人口,对于中国日益下降的人口增长率影响根本不大。 首先,本文通..._运用有限分布滞后模型或其他可行模型,建立模型分析说明二孩政策对生育率

上班摸鱼看小说神器,可以隐藏界面简单安全_桌面看小说的软件 隐蔽-程序员宅基地

文章浏览阅读274次。可调整透明背景,上班偷看小说,老板不会发现,鼠标放上去就有,移开就消失,就是阅读神器,很好用,背景大小可调节,放在哪个角落都不会被发现,如果忙里偷闲可以试一下喔。本软件在桌面显示一块阅读区域,可调整背景透明度、字体大小和颜色,极其小巧精致。用户在上班期间,可放心地偷偷阅读小说,比较隐蔽,避免被同事、老板发现。打游戏、追剧啥的不敢,坐的位置太危险了,电脑屏幕正对门口。官网链接:http://yuedu.chaojizhu.xyz。我用过的最好的看小说软件,调整透明度,自动隐藏,很强大。_桌面看小说的软件 隐蔽

理财课堂日记第6天-程序员宅基地

文章浏览阅读600次。人生是场长跑,你是同学中的哪一个?要知道,高中时候,大家的世界观人生观基本上已经形成了,但是高中时候成绩好的,过了20年来看,未必是事业上最成功的我这里举四个人的例子:A男,我最好的朋友,大学毕业就进入设计院,作为他们系最好的学生被某建筑设计院看中。他当年没考上研究生竟然也是他的运气,因为和他同届考上研究生的人毕业后成为他的下属的下属。37岁当上设计院院长,成为该设计院最年轻院长..._晚上好同学,明晚07:45你的第一节儿理财课就开始了,我是你接下来九天课的专

C网络编程Socket中,Code Runner插件无法右键运行。_coderunner无法运行-程序员宅基地

文章浏览阅读193次。编写一个本地Web项目,如下。使用Ctrl + F5以及点击三角运行均没有问题,但右键Run Code报错。_coderunner无法运行

推荐文章

热门文章

相关标签