List去重的五种方法

List 去重的五种方法
一、借助 Set 的特性进行去重
java 复制代码
/**
* 去除重复数据
* 由于Set的无序性,不会保持原来顺序
* @param list
*/
public static List<String> distinct(List<String> list) {
    final boolean sta = null != list && list.size() > 0;
    List doubleList= new ArrayList();
    if (sta) {
        Set set = new HashSet();
        set.addAll(list);
        doubleList.addAll(set);
    }
    return doubleList;
}
二、利用 Set 集合特性保持顺序一直去重
java 复制代码
// Set去重并保持原先顺序的两种方法
public static void delRepeat(List<String> list) {
    //方法一
    List<String> listNew = new ArrayList<String>(new TreeSet<String>(list));
    //方法二
    List<String> listNew2 = new ArrayList<String>(new LinkedHashSet<String>(list));
}
三、使用 List 自身方法 remove() -> 不推荐
java 复制代码
/**
* 去除重复数据(一般不推荐)
* 类似于冒泡排序思想
* @param list
*/
public static List<Map<String, Object>> distinct(List<Map<String, Object>> list) {
    if (null != list && list.size() > 0) {
        //循环list集合
        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);
                }
            }
        }
    }
    //得到最新移除重复元素的list
    return list;
}
四、遍历 List 集合,将元素添加到另一个 List 集合中
java 复制代码
// 遍历后判断赋给另一个list集合,保持原来顺序
public static List<String> delRepeat(List<String> list) {
	  List<String> listNew = new ArrayList<String>();
	  for (String str : list) {
	       if (!listNew.contains(str)) {
	           listNew.add(str);
	       }
	   }
	  return listNew ;
}
五、使用 Java8 特性去重
java 复制代码
public static List<String> delRepeat(List<String> list) {
     List<String> myList = list.stream().distinct().collect(Collectors.toList());
	 return myList ;
}
相关推荐
Han.miracle2 分钟前
数据结构二叉树——层序遍历&& 扩展二叉树的左视图
java·数据结构·算法·leetcode
筱砚.2 分钟前
【数据结构——最小生成树与Kruskal】
数据结构·算法
蒙奇D索大1 小时前
【数据结构】考研数据结构核心考点:平衡二叉树(AVL树)详解——平衡因子与4大旋转操作入门指南
数据结构·笔记·学习·考研·改行学it
im_AMBER3 小时前
数据结构 04 栈和队列
数据结构·笔记·学习
CAU界编程小白4 小时前
数据结构系列之堆
数据结构·c
Excuse_lighttime5 小时前
只出现一次的数字(位运算算法)
java·数据结构·算法·leetcode·eclipse
liu****5 小时前
笔试强训(二)
开发语言·数据结构·c++·算法·哈希算法
Syntech_Wuz8 小时前
从 C 到 C++:容器适配器 std::stack 与 std::queue 详解
数据结构·c++·容器··队列
艾莉丝努力练剑9 小时前
【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)
linux·开发语言·数据结构·c++·算法
小此方10 小时前
C语言自定义变量类型结构体理论:从初见到精通(下)
c语言·数据结构·算法