我认为标题说明了一切,但
List<Integer> stack ;
List<Integer> exchange;
List<Integer> quora;
堆栈中的值不能交换或quoroa,交换中的值不能在堆栈和quora中,依此类推。
答案 0 :(得分:2)
用一些番石榴胶水构建一个充满你元素的Set
,然后比较尺寸:
final Iterable<Integer> all = Iterables.concat(stack, exchange, quora, ...);
final Set<Integer> unique = Sets.newHashSet(all);
if (Iterables.size(all) > unique.size()) {
// inputs contain duplicate(s)
}
答案 1 :(得分:1)
使用集来查看是否有重复项。
HashSet<Integer> stackSet = new HashSet<>(stack);
HashSet<Integer> exchangeSet = new HashSet<>(exchange);
HashSet<Integer> quoraSet = new HashSet<>(quora);
if(stackSet.removeAll(quoraSet))
; // Error, there were common elements!
答案 2 :(得分:1)
你如何看待subtract的CollectionUtil?不知道这是不是最好的方法,但绝对是一种非常简单的方法!
答案 3 :(得分:1)
理性地说,你可以做类似交集的事情,以确保没有交集。它应该看起来更有意义:
使用Guava库:
HashSet<Integer> stackSet = new HashSet<>(stack);
HashSet<Integer> exchangeSet = new HashSet<>(exchange);
if (! Sets.intersect(stackSet, exchangeSet).isEmpty()) {
// there is intersection between stackSet and exchangeSet
}