java list 去重
时间: 2023-09-12 22:03:04 浏览: 85
可以使用Set来去重,因为Set不允许重复元素,把List中的元素添加到Set中即可去重。代码实现如下:
```java
List<Integer> list = new ArrayList<Integer>();
list.add(1);
list.add(2);
list.add(3);
list.add(2);
list.add(4);
Set<Integer> set = new HashSet<Integer>(list);
list.clear();
list.addAll(set);
System.out.println(list); // [1, 2, 3, 4]
```
另外,Java 8引入了Stream API,可以使用distinct方法来去重,代码如下:
```java
List<Integer> list = Arrays.asList(1, 2, 3, 2, 4);
List<Integer> distinctList = list.stream().distinct().collect(Collectors.toList());
System.out.println(distinctList); // [1, 2, 3, 4]
```
相关问题
java list去重
在Java中,可以使用java.util包中的HashSet类来去除List中的重复元素。HashSet是基于HashMap实现的,它不允许重复元素存在,当向HashSet中添加重复元素时,HashSet会自动将重复元素去重。具体代码如下:
```
List<Integer> originalList = new ArrayList<>(Arrays.asList(1, 2, 2, 3, 3, 4, 5, 5));
Set<Integer> set = new HashSet<>(originalList);
List<Integer> newList = new ArrayList<>(set);
System.out.println(newList);
```
输出结果为:
```
[1, 2, 3, 4, 5]
```
另外,如果要保留List中元素的顺序,可以使用LinkedHashSet,它会按照元素添加的顺序来保留元素。具体代码如下:
```
List<Integer> originalList = new ArrayList<>(Arrays.asList(1, 2, 2, 3, 3, 4, 5, 5));
Set<Integer> set = new LinkedHashSet<>(originalList);
List<Integer> newList = new ArrayList<>(set);
System.out.println(newList);
```
输出结果为:
```
[1, 2, 3, 4, 5]
```
java List去重
在Java中,List是一个有序集合,它允许存储重复元素。如果你想要从List中去除重复的元素,有几种常见的方法:
1. 使用Set:Set不允许有重复元素,你可以将List转换为Set,然后再转换回List,这样就自动去除了重复项。例如:
```java
List<String> list = ...;
Set<String> uniqueList = new HashSet<>(list);
list.clear(); // 清空原来的list
list.addAll(uniqueList);
```
2. 自定义迭代:遍历List,使用HashSet或LinkedHashSet作为临时存储,只添加未见过的元素到新的List中。因为HashSet不保证顺序,所以如果需要保持原始插入顺序,可以使用LinkedHashSet。
```java
List<String> list = ...;
List<String> deduplicatedList = new ArrayList<>();
for (String item : list) {
if (!deduplicatedList.contains(item)) {
deduplicatedList.add(item);
}
}
```
3. 利用Java 8 Stream API:Stream API提供了一个简洁的方式来处理这种操作,通过`distinct()`方法消除重复。
```java
List<String> list = ...;
List<String> uniqueList = list.stream()
.distinct() // 去重
.collect(Collectors.toList());
```
阅读全文