2个List的差分算法

跟两次遍历相比,看到了@ 大胖和二胖 的巧妙算法,借鉴如下:

问题描述:2个list,list1 = {“aaa”, “bbb”, “ccc”}; list2 = {“aaa”, “bbb”, “ddd”}; 需要找到2个list不一样的地方;具体地说,我需要知道list1当中的”ccc”是list2当中没有的,list2当中的”ddd”是list1当中没有的。

解决思路:最傻的办法就是2次循环,极度不推荐,其实有一个非常简便的办法,只是需要我们换一个思路就能想到,用list当中的removeall方法,看代码吧:

List<String> lst1 = new ArrayList<>();
lst1.add("aaa");
lst1.add("bbb");
lst1.add("ccc");

List<String> lst2 = new ArrayList<>();
lst2.add("aaa");
lst2.add("bbb");
lst2.add("ddd");

List<String> tmpLst1 = new ArrayList<>();
tmpLst1.addAll(lst1);

lst1.removeAll(lst2);
lst2.removeAll(tmpLst1);

System.out.println(lst1);
System.out.println(lst2);

links:https://my.oschina.net/dongtianxi/blog/757817

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值