List内数据去重

测试数据如下

public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("张三");
        list.add("李四");
        list.add("王五");
        list.add("张三");//重复的数据
        list.add("赵六");
        System.out.println("oldList = "+list);
        list = removeDuplicate(list);
        System.out.println("newList = "+list);
    }

①使用HashSet去重

public static List<String> removeDuplicate(List<String> list){
        HashSet<String> hs = new HashSet<>();
        hs.addAll(list);
        list.clear();
        list.addAll(hs);
        return list;
    }

结果(缺点:返回的list是顺序和原顺序不一定相同,若需要顺序可以使用LinkedHashSet)

②Iterator遍历去重,结果有序

public static List<String> removeDuplicate(List<String> list){
        Set<String> set = new HashSet<>();    
        List<String> newList = new ArrayList<>();    
        for(Iterator<String> it = list.iterator(); it.hasNext();){    
            String str = it.next();    
            if (set.add(str)){
                newList.add(str);    
            }
        }     
        list.clear();    
        list.addAll(newList);
        return list;
    }

③遍历list利用contains进行判断 (结果有序,效率极低,不推荐)

public static List<String> removeDuplicate(List<String> list){
        List<String> newList = new ArrayList<String>(list.size());
        for (String str : list) {
            if (!newList.contains(str)) {
                newList.add(str);
            }
        }
        list.clear();
        list.addAll(newList);
        return list;
    }

效率测试

public static void main(String[] args) {
        final List<String> list = new ArrayList<String>();
        for (int i = 0; i < 1000; i++) {
            int number = (int)(Math.random()*1000);
            list.add("字符串" + number + "号");
        }
        //第一方式HashSet
        long time = System.currentTimeMillis();
        for (int i = 0; i < 10000; i++) {
            removeDuplicate1(list);
        }
        long time1 = System.currentTimeMillis();
        System.out.println("HashSet        time1:"+(time1-time));
        //第二方式LinkedHashSet
        for (int i = 0; i < 10000; i++) {
            removeDuplicate2(list);
        }
        long time2 = System.currentTimeMillis();
        System.out.println("LinkedHashSet    time2:"+(time2-time1));
        //第三方式iterator
        for (int i = 0; i < 10000; i++) {
            removeDuplicate3(list);
        }
        long time3 = System.currentTimeMillis();
        System.out.println("iterator    time3:"+(time3-time2));
        //第四方式contain
        for (int i = 0; i < 10000; i++) {
            removeDuplicate4(list);
        }
        long time4 = System.currentTimeMillis();
        System.out.println("contain        time4:"+(time4-time3));
    }

结果

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值