java list 子集_java – 列出另一个List忽略大小写的子集?

您可以将a转换为小写字符串的HashSet,这样可以更快地检查子集(因为它需要花费一些时间来检查b的任何元素是否属于aset,而不是检查包含在内的所需的线性时间一个列表):

Set aset = a.stream().map(String::toLowerCase).collect(Collectors.toCollection(HashSet::new));

boolean subset = b.stream().map(String::toLowerCase).allMatch(aset::contains);

P.S.,您正在使用术语子集,但实际上您要检查的不是一个List是否是另一个List的子集,因为您的列表不是集合,这意味着它们可能包含重复值.首先从集合开始会更有意义.

编辑:

如果使用containsAll似乎对你更好,至少在两个集合而不是两个列表上运行它.您将获得线性运行时间而不是二次运行时间:

Set aset = a.stream().map(String::toLowerCase).collect(Collectors.toCollection(HashSet::new));

Set bset = b.stream().map(String::toLowerCase).collect(Collectors.toCollection(HashSet::new));

boolean subset = aset.containsAll(bset);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值