List去除重复数据的五种方式
点击上方 Java学习之道,选择 设为星标
来源
: blog.csdn.net/qq_37939251/article/details/90713643l
作者: 多纤果冻
Part1使用LinkedHashSet删除arraylist中的重复数据
LinkedHashSet
是在一个ArrayList删除重复数据的最佳方法。LinkedHashSet在内部完成两件事:
-
删除重复数据 -
保持添加到其中的数据的顺序
Java示例使用 LinkedHashSet 删除 arraylist 中的重复项。在给定的示例中,numbersList
是包含整数的 arraylist,其中一些是重复的数字,例如1,3和5.我们将列表添加到LinkedHashSet,然后将内容返回到列表中。结果arraylist没有重复的整数。
public static void main(String[] args) {
int List[] =[1, 1, 2, 3, 3, 3, 4, 5, 6, 6, 6, 7, 8]
LinkedHashSet<Integer> hashSet = new LinkedHashSet<>(List);
ArrayList<Integer> listWithoutDuplicates = new ArrayList<>(hashSet);
System.out.println(listWithoutDuplicates);
}
输出结果
[1, 2, 3, 4, 5, 6, 7, 8]
Part2使用java8新特性stream进行List去重
要从arraylist中删除重复项,我们也可以使用 java 8 stream api。使用 steam 的 distinct() 方法返回一个由不同数据组成的流,通过对象的 equals() 方法进行比较。
收集所有区域数据List使用 Collectors.toList()。
Java程序,用于在不使用Set的情况下从java中的arraylist中删除重复项。
public static void main(String[] args){
int List[] =[1, 1, 2, 3, 3, 3, 4, 5, 6, 6, 6, 7, 8]
List<Integer> listWithoutDuplicates = List.
stream().
distinct().
collect(Collectors.toList());
System.out.println(listWithoutDuplicates);
}
Part3利用HashSet不能添加重复数据的特性
由于HashSet不能保证添加顺序,所以只能作为判断条件保证顺序:
private static void removeDuplicate(List<String> list) {
HashSet<String> set = new HashSet<String>(list.size());
List<String> result = new ArrayList<String>(list.size());
for (String str : list) {
if (set.add(str)) {
result.add(str);
}
}
list.clear();
list.addAll(result);
}
Part4利用List的contains方法循环遍历,重新排序,只添加一次数据,避免重复
private static void removeDuplicate(List<String> list) {
List<String> result = new ArrayList<String>(list.size());
for (String str : list) {
if (!result.contains(str)) {
result.add(str);
}
}
list.clear();
list.addAll(result);
}
Part5双重for循环去重
public static void main(String[] args) {
int List[] = [1, 1, 2, 3, 3, 3, 4, 5, 6, 6, 6, 7, 8]
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);
j--;
}
}
}
}
- | 更多精彩文章 -
▽加我微信,交个朋友 长按/扫码添加↑↑↑
评论