判断list 中是否有重复的元素

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/xiaofanren1111/article/details/82349053

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

            }

        }

    }

猜你喜欢

转载自blog.csdn.net/xiaofanren1111/article/details/82349053