幽兰生空谷
--绝世独自开

两个List<T> 之间求:交集、差集、并集、去重后的并集

两个list声明:

/**
         * 1.从一个list中移除另一个list的值(求差集)
         * 2.利用list的removeAll()方法移除
         */
        String oldStr = "1,2,3,4,5";
        String newStr = "4,5,6,7,8";

        String[] strings1 = oldStr.split(",");
        List<String> oldStrList = new ArrayList<>(Arrays.asList(strings1));
        System.out.println(oldStrList);
        String[] strings = newStr.split(",");
        List<String> newStrList = new ArrayList<>(Arrays.asList(strings));
        System.out.println(newStrList);

输出:

[1, 2, 3, 4, 5]
[4, 5, 6, 7, 8]

求交集 retainAll()

  • oldStrList与 newStrList 的交集
oldStrList.retainAll(newStrList);
        System.out.println("oldStrList与newStrList并集(即在 oldStrList 与 newStrList 集合中都有的元素):" );
        System.out.println(oldStrList);

输出:

oldStrList与newStrList并集(即在 oldStrList 与 newStrList 集合中都有的元素):
[4, 5]
  • newStrList 与 oldStrList的交集
newStrList.retainAll(oldStrList);
        System.out.println("newStrList与oldStrList并集(即在 newStrList 与 oldStrList 集合中都有的元素):" );
        System.out.println(newStrList);

输出:

newStrList与oldStrList并集(即在 newStrList 与 oldStrList 集合中都有的元素):
[4, 5]

求差集 removeAll()

  • oldStrList与 newStrList的差集
        oldStrList.removeAll(newStrList);
        System.out.println("oldStrList与newStrList差集(即在 oldStrList 集合中,删掉 oldStrList 与 newStrList 中都有的元素):" );
        System.out.println(oldStrList);

输出:

oldStrList与newStrList差集(即在 oldStrList 集合中,删掉 oldStrList 与 newStrList 中都有的元素):
[1, 2, 3]
  • newStrList与 oldStrList的差集
newStrList.removeAll(oldStrList);
        System.out.println("newStrList与oldStrList差集(即在 newStrList 集合中,删掉 newStrList 与 oldStrList 中都有的元素):" );
        System.out.println(newStrList);

输出:

newStrList与oldStrList差集(即在 newStrList 集合中,删掉 newStrList 与 oldStrList 中都有的元素):
[6, 7, 8]

求并集 addAll()

  • newStrList与 oldStrList的并集
newStrList.addAll(oldStrList);
        System.out.println("newStrList与oldStrList并集(即在 newStrList 集合中,newStrList 与 oldStrList 中都有的元素):" );
        System.out.println(newStrList);

输出:

newStrList与oldStrList并集(即在 newStrList 集合中,newStrList 与 oldStrList 中都有的元素):
[4, 5, 6, 7, 8, 1, 2, 3, 4, 5]
  • oldStrList与 newStrList的并集
oldStrList.addAll(newStrList);
        System.out.println("newStrList与oldStrList并集(即在 newStrList 集合中,newStrList 与 oldStrList 中都有的元素):" );
        System.out.println(oldStrList);

输出:

newStrList与oldStrList并集(即在 newStrList 集合中,newStrList 与 oldStrList 中都有的元素):
[1, 2, 3, 4, 5, 4, 5, 6, 7, 8]

求去重后的并集

  • oldStrList与 newStrList去重后的并集
oldStrList.removeAll(newStrList);
        oldStrList.addAll(newStrList);
        System.out.println("newStrList与oldStrList去重后的并集(即在先移除后合并):" );
        System.out.println(oldStrList);

输出

newStrList与oldStrList去重后的并集(即在先移除后合并):
[1, 2, 3, 4, 5, 6, 7, 8]
  • newStrList与 oldStrList去重后的并集
newStrList.removeAll(oldStrList);
        newStrList.addAll(oldStrList);
        System.out.println("newStrList与oldStrList去重后的并集(即在先移除后合并):" );
        System.out.println(newStrList);

输出:

newStrList与oldStrList去重后的并集(即在先移除后合并):
[6, 7, 8, 1, 2, 3, 4, 5]
赞(3) 打赏
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《两个List<T> 之间求:交集、差集、并集、去重后的并集》
文章链接:https://www.itheibai.com/archives/972
免责声明:根据《计算机软件保护条例》第十七条规定“为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。”您需知晓本站所有内容资源均来源于网络,仅供用户交流学习与研究使用,版权归属原版权方所有,版权争议与本站无关,用户本人下载后不能用作商业或非法用途,需在24个小时之内从您的电脑中彻底删除上述内容,否则后果均由用户承担责任;如果您访问和下载此文件,表示您同意只将此文件用于参考、学习而非其他用途,否则一切后果请您自行承担,如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
本站是非经营性个人站点,所有软件信息均来自网络,所有资源仅供学习参考研究目的,并不贩卖软件,不存在任何商业目的及用途,网站会员捐赠是您喜欢本站而产生的赞助支持行为,仅为维持服务器的开支与维护,全凭自愿无任何强求。

评论 抢沙发

评论前必须登录!

 

养成“打赏”的好习惯,从我做起!

非常感谢你的打赏,我们将继续给力更多优质内容,让我们一起创建更加美好的网络世界!

支付宝扫一扫

微信扫一扫

登录

找回密码

注册