1,
但是,在java8中,可以通过stream来判断,非常简单:
List<Integer> list = new ArrayList() {
{
add(1);
add(2);
add(1);
}
};
long count = list.stream().distinct().count();
boolean isRepeat = count < list.size();
System.out.println(count);//输出2
System.out.println(isRepeat);//输出true
2
List是有序的可重复集合, 如果要判断list中是否有一个元素 , 可以用 list.contains(obj)
如果只是为了判断list中是否有重复 , 方法有很多种, 比如可以将list转换为set
Set set = new HashSet<>(list);
set是无需不可重复的集合 , list转成set之后 , 如果set的size比 list的size小 , 说明有重复元素
也可以遍历list , 放入Map , 用list的泛型作为 map 的 key 类型 , 而出现的次数作为 map的value , 这样就能很容易看出来 list中的元素有没有重复 , 哪个有重复 , 重复了几次
public
static
void
main(String[] args) {
Set<String> s =
new
HashSet<String>();
List<String> l =
new
ArrayList<String>();
l.add(
"1"
);
l.add(
"2"
);
l.add(
"2"
);
l.add(
"3"
);
for
(String str : l) {
boolean
b = s.add(str);
if
(!b){
System.out.println(str);
}
}
}