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