ArrayList数组去重

ArrayList数组去重

运行结果

java 复制代码
原数组 : [3, 3, 1, 2, 5, 6, 8, 6, 4, 2]
XXXXXX 去重后数组 : [3, 1, 2, 5, 6, 8, 4]

1.LinkedHashSet

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));
List<Integer> listByLinkedHashSet = new ArrayList<>(new LinkedHashSet<>(list));
System.out.println("原数组 : " + list);
System.out.println("LinkedHashSet 去重后数组 : " + listByLinkedHashSet);

2.HashSet

由于HashSet不能保证添加顺序,所以只能作为判断条件保证顺序

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));

HashSet<Integer> set = new HashSet<Integer>();
List<Integer> listByHashSet = new ArrayList<Integer>();
for (Integer num : list) {
    if (set.add(num)) {
        listByHashSet.add(num);
    }
}

System.out.println("原数组 : " + list);
System.out.println("HashSet 去重后数组 : " + listByHashSet);

如果不计较去重后的数据顺序,可以直接使用HashSet进行去重

HashSet hashSet = new HashSet<>(list);

List listByHashSet = new ArrayList<>(hashSet);

3.steam的distinct()方法

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));
List<Integer> listByStream = list.stream().distinct().collect(Collectors.toList());
System.out.println("原数组 : " + list);
System.out.println("Stream 去重后数组 : " + listByStream);

4.steam的filter()方法

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));

List<Integer> listByFilter = new ArrayList<>(list.size());
list.stream().filter(i -> {
    if (listByFilter.indexOf(i) == -1){
        listByFilter.add(i);
    }
    return false;
}).collect(Collectors.toList());

System.out.println("原数组 : " + list);
System.out.println("filter 去重后数组 : " + listByFilter);

5.contains()方法

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));

List<Integer> listByContains = new ArrayList<>(list.size());
for (Integer num : list) {
    if (!listByContains.contains(num)) {
        listByContains.add(num);
    }
}

System.out.println("原数组 : " + list);
System.out.println("Contains 去重后数组 : " + listByContains);

6.indexOf()方法

markup 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));

List<Integer> listByIndexOf = new ArrayList<>(list.size());
for (int i = 0; i < list.size(); i++) {
    if (listByIndexOf.indexOf(list.get(i)) == -1){
        listByIndexOf.add(list.get(i));
    }
}

System.out.println("原数组 : " + list);
System.out.println("ForLoop 去重后数组 : " + listByIndexOf);

7.lastIndexOf()方法

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));
System.out.println("原数组 : " + list);

for (int i = 0; i < list.size(); i++) {
    if (list.indexOf(list.get(i)) != list.lastIndexOf(list.get(i))) {
        list.remove(list.lastIndexOf(list.get(i)));
    }
}

System.out.println("lastIndexOf 去重后数组 : " + list);

8.双重for循环

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));
System.out.println("原数组 : " + list);

for (int i = 0; i < list.size(); i++) {
    for (int j = i+1; j < list.size(); j++) {
        if(list.get(i)==list.get(j)) {
            list.remove(j);
        }
    }
}
System.out.println("ForLoop 去重后数组 : " + list);

9.sort 排序

排序之后,如果相邻两个元素是相等的,那么就说明重复了。(但这个方法会改变数组原有顺序)

java 复制代码
List<Integer> list = new ArrayList<>(Arrays.asList(3, 3, 1, 2, 5, 6, 8, 6, 4, 2));
Collections.sort(list);

List<Integer> listBySort = new ArrayList<>(list.size());
listBySort.add(list.get(0));
for (int i = 1; i < list.size(); i++) {
    if (list.get(i-1) != list.get(i)) {
        listBySort.add(list.get(i));
    }
}

System.out.println("原数组 : " + list);
System.out.println("Sort 去重后数组 : " + listBySort);
相关推荐
格发许可优化管理系统3 分钟前
Mentor许可证与其他软件许可证的深度比较
java·大数据·运维·c语言·c++·算法
pingglala12 分钟前
winscp连接linux失败解决方法
java·linux·服务器
Javatutouhouduan12 分钟前
深入学习JVM底层原理:源码剖析与实例详解!
java·jvm·java面试·后端开发·java程序员·java八股文·java性能优化
Flynt16 分钟前
我把 JDK21 虚拟线程用成了"性能灾难",复盘完发现踩了三个大坑
java·ai编程
做一个快乐的小傻瓜22 分钟前
ZYNQ DEV套件引脚约束
java·linux·运维
CoderYanger22 分钟前
Java EE:6.网络编程套接字(第二弹)
java·网络·程序人生·面试·职场和发展·java-ee·学习方法
devilnumber22 分钟前
Java Lambda 表达式 200 条常见问题、坑点、易错点、规范清单
java·开发语言
极客先躯24 分钟前
高级java每日一道面试题-2026年02月12日-实战篇[Docker]-什么是容器的 Seccomp 配置?如何自定义?
java·运维·分布式·docker·容器·自动化·文件
大大杰哥26 分钟前
Vue2学习(3)--组件中的通信方式/组件之间的交互
java·前端·javascript
zzz_236826 分钟前
【Java基础】二叉树遍历与红黑树的完美平衡艺术——从递归崩溃到自平衡的硬核拆解
java·开发语言