java – 查找两个数组之间的非公共元素

前端之家收集整理的这篇文章主要介绍了java – 查找两个数组之间的非公共元素前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在一次采访中,人们被要求在两个字符串数组之间找到非常见的元素.
Eg: String a[]={"a","b","c","d"}; 
String b[]={"b","c"}; 
O/p should be a,d

我回答了Java Set中使用HashTable实现的问题.使用Set的代码更简单:

String[] a = {"a","d"};
String[] b = {"b","c"};

Set<String> set = new HashSet<>(a.length);
for(String s : a){
    set.add(s);
}
for(String s : b){
    set.remove(s);
}
return set;

现在我的问题是,有没有其他更好的方法来实现这一目标

解决方法

您可以缩短代码
TreeSet set = new TreeSet(Arrays.asList(a));
set.removeAll(Arrays.asList(b));

Demo

猜你在找的Java相关文章