android list比较大小写,列出另一个List <string>忽略大小写的<string>子集?

3 个答案:

答案 0 :(得分:6)

将数组转换为小写:

a.stream().map(String::toLowerCase).collect(Collectors.toList());

b.containsAll(a);

答案 1 :(得分:4)

您可以将a转换为HashSet小写String,这样可以更快地检查子集(因为它需要花费很长时间来检查是否有任何元素b属于aset,而不是检查包含在List中所需的线性时间):

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

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

PS,您使用的是子集一词,但实际上您要检查的不是一个List是另一个的{strong>子集,由于您的List不是Set s,这意味着它们可能包含重复值。首先从Set开始是更有意义的。

编辑:

如果使用containsAll似乎更好,至少在两个Set而不是两个List上运行它。您将获得线性运行时间而不是二次运行时间:

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);

答案 2 :(得分:0)

您可以使用不区分大小写的Comparator创建TreeSet的子类

public class MyStringSet extends TreeSet {

private static class CaseInsensiteStringComparator implements Comparator {

@Override

public int compare(String a, String b) {

return a.toLowerCase().compareTo(b.toLowerCase());

}

}

public MyStringSet() {

super(new CaseInsensiteStringComparator());

}

public MyStringSet(Collection extends String> arg0) {

super(new CaseInsensiteStringComparator());

addAll(arg0);

}

public MyStringSet(Comparator super String> arg0) {

super(arg0);

}

public MyStringSet(SortedSet arg0) {

super(new CaseInsensiteStringComparator());

addAll(arg0);

}

public static void main(String[] args) {

List b = Arrays.asList("eins", "drei", "zwei");

MyStringSet a = new MyStringSet(Arrays.asList("Vier", "DRei", "zWei", "einS"));

System.out.println(a.containsAll(b));

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值