java 判断两个List是否包含 判断两个list相等

这篇具有很好参考价值的文章主要介绍了java 判断两个List是否包含 判断两个list相等。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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和
-----------------------------------文章来源地址https://www.toymoban.com/news/detail-767219.html

到了这里,关于java 判断两个List是否包含 判断两个list相等的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 记录--如何判断两个数组的内容是否相等

    给定两个数组,判断两数组内容是否相等。 不使用排序 不考虑元素位置 例: 思考几秒:有了😀😀 直接遍历第一个数组,并判断是否存在于在第二个数组中 求差集, 如果差集数组有长度,也说明两数组不等(个人感觉比上面的麻烦就不举例了) 细心的小伙伴就会发现:N

    2024年02月08日
    浏览(32)
  • java中判断list是否为空

    java中判断list是否为空是日常代码中经常遇到的问题。最近发现一个Utils提供的方法可以一步判断。 废话不多说,直接上代码! 结果: 注意:需要pom文件需要引入 import org.apache.commons.collections4.CollectionUtils;

    2024年02月15日
    浏览(36)
  • 在JS中如何判断两个对象是否相等

    在JavaScript中,判断两个对象是否相等有多种方法,取决于你对 相等 的定义以及对象属性的类型。以下是几种常见的方法:   1. 严格相等运算符 (===) 使用 === 运算符可以比较两个对象是否引用同一个对象。如果两个变量引用了同一个对象,则它们是相等的,否则它们是不相等

    2024年02月03日
    浏览(36)
  • java实用小技巧:判断list是否有重复项

    在项目中经常会遇到这样的场景,就是一个list,根据某种规则,我要去判断里面是不是有重复的项。 难度不高,但有点烦,所以专门开一篇文章来记录一下,争取弄一个相对简洁的写法。 先看一个简单的例子:  这是一个泛型方法 `distinctList`,它接受一个 `List` 类型的参数

    2023年04月14日
    浏览(29)
  • js 判断两个字符串是否相等(有两种方法)

    使用比较运算符判断两个字符串是否相等 可以使用比较运算符 === 或 == 来判断两个字符串是否相等。例如: 在上述代码中,我们定义了两个字符串变量 str1 和 str2 ,并使用 === 运算符来比较它们的值。如果两个字符串相等,则输出 两个字符串相等 ;否则输出 两个字符串不相

    2024年02月05日
    浏览(48)
  • Python字符串比较:如何判断两个字符串是否相等?

    Python字符串比较:如何判断两个字符串是否相等? 在Python编程中,字符串是最常用的数据类型之一。当我们需要比较两个字符串时,通常需要判断它们是否相等。这篇文章将详细介绍Python中比较两个字符串的方法。 使用“==”运算符比较字符串 在Python中,可以使用“==”运算

    2023年04月11日
    浏览(44)
  • 【python基础知识】python中怎么判断两个字符串是否相等

    目录 有哪些判断方法 1. == 运算符 2. is 运算符 有哪些特殊情况 1. 字符串中包含空格、换行符、制表符等特殊字符 2. 字符串编码格式的不同 3. 字符串对象的创建方式不同 注意事项 1. 避免使用is运算符进行字符串比较 2. 注意空格、换行符、制表符等特殊字符的影响 3. 注意字符

    2024年02月08日
    浏览(54)
  • Java判断List集合中的对象是否包含有某一元素

    关于以下方法,直接可以在自己项目创建一个类,然后进行测试使用!文本末尾也提供了每个方法的运行结果,供大家参考使用! 文章大量使用到了Java8当中的Lambda表达式,以及stream流相关基础知识。如果您用的不熟,没关系,可以直接复制下面的方案然后进行套着使用即可

    2024年02月11日
    浏览(60)
  • 检查一个Java List是否包含某个JavaBean对象的特定值,并且获取这个值

    在这个例子中,我们使用了Java 8的 Optional 类来处理可能不存在的结果。如果找到了匹配的Bean对象,我们可以使用 get() 方法获取它,并打印出其名称。如果没有找到匹配的Bean对象, isPresent() 方法将返回 false ,我们将打印出相应的消息。

    2024年01月24日
    浏览(37)
  • python判断是否为list。转

    python判断是否为list ( - )浩( - )浩2019-08-31 09:05:39原创 判断是否为列表 格式:print(isinstance(变量,list)) 1 print(isinstance(slink,list)) 结果 :true说明为列表(list) 返回false说明不是列表(list) 获取类型 print(type(slink)) 执行结果为:class ‘list’说明为列表类型 isinstance和type区别 isinst

    2023年04月08日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包