如何去除 List 中的重复元素?我一行代码搞定,赶紧拿去用!

List 去重方案

假设有以下数据:

/**
 * 3 个张三,2 个李强
 */
public List<String> initList = Arrays.asList(
    "张三", 
    "李四", 
    "张三", 
    "周一", 
    "刘四", 
    "李强", 
    "李白", 
    "张三", 
    "李强", 
    "王五"
);

1、for 循环添加去重

/**
 * for 循环添加去重
 * @author: 栈长
 * @from: Java技术栈
 */
@Test
public void remove1() {
    List<String> list = new ArrayList(initList);
    List<String> list2 = new ArrayList<>();
    for (String element : list) {
        if (!list2.contains(element)) {
            list2.add(element);
        }
    }
    System.out.println(list2);
}

这个是最基本的实现了,创建一个空的 List,添加前判断一下存在不存在,不存在才添加,这样就保证了元素不重复。

输出结果:

[张三, 李四, 周一, 刘四, 李强, 李白, 王五]

 

2、for 双循环去重

/**
 * for 双循环去重
 * @author: 栈长
 * @from: Java技术栈
 */
@Test
public void remove2() {
    List<String> list = new ArrayList(initList);
    for (int i = 0; i < list.size() - 1; i++) {
        for (int j = list.size() - 1; j > i; j--) {
            if (list.get(j).equals(list.get(i))) {
                list.remove(j);
            }
        }
    }
    System.out.println(list);
}

利用双循环,判断是否有相等的,再进行移除。

输出结果:

[张三, 李四, 周一, 刘四, 李强, 李白, 王五]

 

3、for 循环重复坐标去重

/**
 * for 循环重复坐标去重
 * @author: 栈长
 * @from: Java技术栈
 */
@Test
public void remove3() {
    List<String> list = new ArrayList(initList);
    List<String> list2 = new ArrayList(initList);
    for (String element : list2) {
        if (list.indexOf(element) != list.lastIndexOf(element)) {
            list.remove(list.lastIndexOf(element));
        }
    }
    System.out.println(list);
}

这种方式很新颖吧?

复制一个 list2,再循环 List2,判断 list 中的元素的首尾出现的坐标位置是否一致,如果一致,则说明没有重复的,否则重复,再删除重复的位置的元素。

输出结果:

[张三, 李四, 周一, 刘四, 李强, 李白, 王五]

4、Set 去重

/**
 * Set 去重
 * @author: 栈长
 * @from: Java技术栈
 */
@Test
public void remove4() {
    List<String> list = new ArrayList(initList);
    List<String> list2 = new ArrayList(new HashSet(list));
    System.out.println(list2);
}

这招也太简单了吧,一行代码搞定!

我们知道 Set 是不包含重复元素的,把 List 先装进 HashSet,然后再装回来,这样就保证了元素的不重复。

输出结果:

[李强, 李四, 张三, 周一, 李白, 王五, 刘四]

结果虽然正确,但元素顺序和原始 List 不一致,如果要保证顺序性,可以把 HashSet 换成 LinkedHashSet:

/**
 * Set 去重
 * @author: 栈长
 * @from: Java技术栈
 */
@Test
public void remove4() {
    List<String> list = new ArrayList(initList);
    List<String> list2 = new ArrayList(new LinkedHashSet(list));
    System.out.println(list2);
}

输出结果:

[张三, 李四, 周一, 刘四, 李强, 李白, 王五]

这下顺序对了吧,LinkedHashSet 可以保证元素的顺序性!

 

5、Stream 去重

/**
 * Stream 去重
 * @author: 栈长
 * @from: Java技术栈
 */
@Test
public void remove5() {
    List<String> list = new ArrayList(initList);
    list = list.stream().distinct().collect(Collectors.toList());
    System.out.println(list);
}

利用 Stream 的 distinct 方法去重,这个方法也十分简单,一行代码搞定!

输出结果:

[张三, 李四, 周一, 刘四, 李强, 李白, 王五]

总结

本文总结了 5 种去除 List 重复元素的方法:

  • for 循环添加去重

  • for 双循环去重

  • for 循环重复坐标去重

  • Set 去重

  • Stream 去重

最后两种方案最简单,都是一行代码就能搞定的,推荐使用!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用列表推导式和 set() 函数来删除数组多个相同元素。具体代码如下: ```python arr = [1, 2, 3, 2, 4, 3, 5, 6, 5] arr = list(set([i for i in arr])) print(arr) ``` 输出结果为:[1, 2, 3, 4, 5, 6] ### 回答2: 在Python,可以使用列表推导式或集合(set)来删除数组的多个相同元素。 1. 使用列表推导式: 列表推导式是一种构建新列表的方法,可以通过遍历原始数组,并使用条件判断来选择要保留的元素,从而实现删除重复元素的效果。 例如,假设原始数组为arr,要删除的元素为value,可以使用以下代码进行删除操作: ```python arr = [1, 2, 3, 2, 4, 3, 5] value = 2 new_arr = [x for x in arr if x != value] ``` 这段代码会生成一个新的列表new_arr,其排除了与value相等的元素。输出结果为[1, 3, 4, 3, 5]。 2. 使用集合(set): 集合是一种无序且唯一的对象集合,可以利用这个特性来删除数组重复元素。将数组转换为集合,然后再转换回列表即可。 例如,假设原始数组为arr,可以使用以下代码进行删除操作: ```python arr = [1, 2, 3, 2, 4, 3, 5] new_arr = list(set(arr)) ``` 上述代码会首先将arr转换为集合,然后再转换为列表。输出结果为[1, 2, 3, 4, 5]。 需要注意的是,上述方法会打乱元素的原始顺序,如果要保持顺序不变,可以使用有序集合来进行操作,例如使用collections模块的OrderedDict()函数。 综上所述,可以使用列表推导式或集合来删除数组的多个相同元素。 ### 回答3: 在Python,可以使用循环结合删除方法来删除数组的多个相同元素。下面是一个示例代码: ```python def remove_duplicates(arr): # 用一个空列表来存储去重后的元素 result = [] # 遍历数组的每一个元素 for elem in arr: # 如果元素不在结果列表中,则将其添加到结果列表中 if elem not in result: result.append(elem) return result # 示例用法 my_array = [1, 2, 3, 4, 3, 2, 1, 5, 6, 5, 4] result_array = remove_duplicates(my_array) print(result_array) ``` 运行结果为: ``` [1, 2, 3, 4, 5, 6] ``` 在上述代码,`remove_duplicates`函数接受一个数组作为输入,并返回一个去重后的新数组。它通过遍历输入数组的每一个元素,判断该元素是否已经存在于结果列表中,若不存在则将该元素添加到结果列表中。最后,函数返回结果列表。 需要注意的是,这种方法删除的是连续出现的相同元素,如果需要删除所有相同的元素,可以使用`collections.Counter`模块来完成。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值