前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【集合】List取交集、并集(去重)、差集 - Java技术债务

【集合】List取交集、并集(去重)、差集 - Java技术债务

作者头像
Java技术债务
发布2024-06-21 17:01:48
1120
发布2024-06-21 17:01:48
举报
文章被收录于专栏:Java技术债务

交集

最笨的方法之一:双层for循环(对象的情况下可以转成map或者set)

代码语言:javascript
复制
public static void main(String[] args) {
        List listA = new ArrayList<>();
        List listB = new ArrayList<>();
        listA.add("A");
        listA.add("B");
        listA.add("C");
        listA.add("D");
        listB.add("B");
        listB.add("C");
        listB.add("D");
        listB.add("E");
        Set set = new HashSet();
        for (String tmp: listA) {
            set.add(tmp);
        }
        for (String tmp: listB) {
            if(set.contains(tmp)){
                System.out.println(tmp);
            }
        }
    }

上边代码可以简化为一行代码,使用List源码中retainAll(List list)

代码语言:javascript
复制
listA.retainAll(listB)
结果:
B,C,D
【集合】List取交集、并集(去重)、差集 - Java技术债务
【集合】List取交集、并集(去重)、差集 - Java技术债务

ArrayList对此方法进行了重写,先对传入的参数进行了非空判断

【集合】List取交集、并集(去重)、差集 - Java技术债务
【集合】List取交集、并集(去重)、差集 - Java技术债务

然后调用了batchRemove方法执行取交集逻辑

代码语言:javascript
复制
 final Object[] elementData = this.elementData;

这里要注意的是这样赋值,elementData引用还是指向this.elementData,所以后面直接操作elementData改变的会是this。

对自身进行了遍历,在遍历的过程中判断传进来的集合中是否包含当前元素,如果包含,则按顺序写入当前集合中。

第二个判断就是将交集后面多余的元素去除。

【集合】List取交集、并集(去重)、差集 - Java技术债务
【集合】List取交集、并集(去重)、差集 - Java技术债务

差集

代码语言:javascript
复制
public static void main(String[] args) {
        List listA = new ArrayList<>();
        List listB = new ArrayList<>();
        listA.add("A");
        listA.add("B");
        listA.add("C");
        listA.add("D");
        listB.add("B");
        listB.add("C");
        listB.add("D");
        listB.add("E");
        List listC = new ArrayList<>();
        listC.addAll(listA);
        // 方法一: for循环
        for (String s : listB) {
            listA.remove(s);
        }
        System.err.println(listA);
        // 方法二: list自带方法
        listC.removeAll(listB);
        System.err.println(listC);
    }
结果:
[A]
[A]
【集合】List取交集、并集(去重)、差集 - Java技术债务
【集合】List取交集、并集(去重)、差集 - Java技术债务

并集

不去重

代码语言:javascript
复制
public static void main(String[] args) {
        List listA = new ArrayList<>();
        List listB = new ArrayList<>();
        listA.add("A");
        listA.add("B");
        listA.add("C");
        listA.add("D");
        listB.add("B");
        listB.add("C");
        listB.add("D");
        listB.add("E");
				listA.addAll(listB);
    }
结果:
[A, B, C, D, B, C, D, E]

去重

代码语言:javascript
复制
public static void main(String[] args) {
            List listA = new ArrayList<>();
            List listB = new ArrayList<>();
            listA.add("A");
            listA.add("B");
            listA.add("C");
            listA.add("D");
            listB.add("B");
            listB.add("C");
            listB.add("D");
            listB.add("E");
            List listC = new ArrayList<>();
            listC.addAll(listA);
            // 方法一: for循环
            for (String s : listB) {
                if (!listA.contains(s)) {
                    listA.add(s);
                }
            }
            System.err.println(listA);
            // 方法二: list自带方法
            listC.removeAll(listB);
            listC.addAll(listB);
            System.err.println(listC);
    }
结果:
[A, B, C, D, E]
[A, B, C, D, E]
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-11-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 交集
  • 差集
  • 并集
    • 不去重
      • 去重
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档