今天突然想起之前有一次面试的一道笔试题,但是当时没有做出来,所以今天把它做出来了,顺便记录一下。
题目如下:从[1, 5, 3, 2, 1, 9, 3, 6, 7, 5]中筛选出未重复的元素(也就是只出现一次的元素),虽然用笨一点的方法for循环也可以实现,但是我想用lambda去实现,但是后面还是没有做出来,二话不多说,直接上代码。
List<Integer> number = Arrays.asList(1, 5, 3, 2, 1, 9, 3, 6, 7, 5);
// 筛选不重复的
List<Integer> unrepeated = number.stream()
.filter(
t1 -> number.stream().filter(t2 -> t1.equals(t2)).count() <= 1
)
.collect(Collectors.toList());
System.out.println("unrepeated -> " + unrepeated);
输出结果如下