List 去重6种

List 去重

1、List 去重

/**
 * 自定义去重
 * @param list
 */
public static void method(List<Integer> list) {
    // 新集合
    List<Integer> newList = new ArrayList<>(list.size());
    list.forEach(i -> {
        if (!newList.contains(i)) { // 如果新集合中不存在则插入
            newList.add(i);
        }
    });
    System.out.println("去重集合:" + newList);
}

2、迭代器去重(无序)

/**
 * 使用迭代器去重
 * @param list
 */
public static void method_1(List<Integer> list) {
    Iterator<Integer> iterator = list.iterator();
    while (iterator.hasNext()) {
        // 获取循环的值
        Integer item = iterator.next();
        // 如果存在两个相同的值
        if (list.indexOf(item) != list.lastIndexOf(item)) {
            // 移除前面那个相同的值
            iterator.remove();
        }
    }
    System.out.println("去重集合:" + list);
}

3、HashSet去重(无序)

/**
 * 使用 HashSet 去重
 * @param list
 */
public static void method_2(List<Integer> list) {
    HashSet<Integer> set = new HashSet<>(list);
    System.out.println("去重集合:" + set);
}

4、TreeSet去重(无序)

/**
 * 使用 TreeSet 去重(无序)
 * @param list
 */
public static void method_4(List<Integer> list) {
    TreeSet<Integer> set = new TreeSet<>(list);
    System.out.println("去重集合:" + set);
}

5、LinkedHashSet去重(有序)

/**
 * 使用 LinkedHashSet 去重
 * @param list
 */
public static void method_3(List<Integer> list) {
    LinkedHashSet<Integer> set = new LinkedHashSet<>(list);
    System.out.println("去重集合:" + set);
}

6、Stream去重(有序)

/**
 * 使用 Stream 去重
 * @param list
 */
public static void method_5(List<Integer> list) {
    list = list.stream().distinct().collect(Collectors.toList());
    System.out.println("去重集合:" + list);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值