List元素去重的六种方式

article/2025/9/22 9:36:40

        上周的时候完成公司交付的任务,突然间遇到了需要把重复元素去掉的功能,当时我的大脑飞速运转,努力回想以前学习关于list的知识,后来,我发现已经忘得差不多了,所以我就找到了这篇文章,说的很详细。本来打算当时就记笔记的,后来无奈太忙了,所以拖了一周多才完成。
以下将通过六种方式将list集合内的元素去重,选择一个简单的方法记住它吧!


这篇文章参考了很多资料,感谢老师们的贡献,原文链接在这儿  
【List数据去重的五种有效方法】

目录

    可以自动排序的: 

方法一:利用TreeSet集合特性保持顺序一致去重

    不可自动排序的:

方法二:借助Set的特性进行去重

方法三:利用LinkedHashSet集合去重

方法四:使用list.contains()对全部元素进行判断

方案五: 使用Java8特性去重

方法六:使用list自身方法remove()–>不推荐


方法一:利用TreeSet集合特性排序+去重

TreeSet可以将字符串类型的数据按照字典顺序进行排序,首字母相同则看第二位

public static List<String> delRepeat1(List<String> list) {List<String> strings = new ArrayList<>(new TreeSet<>(list));return strings;
}

原:22    11    33    55    66    22    33    66

去重后:11    22    33    55    66    


方法二:借助Set的特性进行去重

由于Set的特性是无需且不可重复,我们利用这个特性进行两部操作
(1)把list放入set中
(2)把set还回list里

public static List<String> distinct(List<String> list) {List doubleList = new ArrayList();if(list.size()>0&&list != null){ //判断传入的list是否为空Set set = new HashSet(); //新建一个HashSetset.addAll(list); //list里的所有东西放入set中 进行去重doubleList.addAll(set); //把去重完的set重新放回list里}return doubleList;
}

原:22    11    33    55    66    22    33    66

去重后:22    11    33    55    66    


方法三:利用LinkedHashSet集合去重

经过验证之后发现,LinkedHashSet虽然可以去重,但是根据他的特性,他不能对数据进行排序,只能维持原来插入时的秩序
就因为这个知识论坛还有吵架的~

 public static List<String> delRepeat1(List<String> list) {List<String> listNew2 = new ArrayList<String>(new LinkedHashSet<String>(list));return listNew2;}

原:22    11    33    55    66    22    33    66

去重后:22    11    33    55    66    


方法四:使用list.contains()对全部元素进行判断

为了探究contains()方法的作用,我特意用List和String两种类型分别尝试了一下
结果长这样

String aaa = "aaa"; //声明一个String
String aa = "aa"; //再声明一个不同的String
boolean b = aaa.contains(aa); //比较一下 结果为trueList<String> listA = new ArrayList<String>(); //新建一个list
listA.add("aaa"); //添加一个String类型的元素
boolean b = listA.contains("aa"); //比较一下 结果为false


String类型会判断字符串里是否有相同的部分
List里则会判断是否有相同的元素
有了这样的结果,我们就可以用list.contains()的方法进行判断,然后将其添加到新的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 ;
}

原:22    11    33    55    66    22    33    66

去重后:22    11    33    55    66    


方案五: 使用Java8特性去重

这部分没有深究,大概意思就是把list集合->Stream流,然后对流用distinct()去重,再用collect()收集

public static List<String> delRepeat(List<String> list) {List<String> myList = list.stream().distinct().collect(Collectors.toList());return myList ;
}

原:22    11    33    55    66    22    33    66

去重后:22    11    33    55    66    


方法六:使用list自身方法remove()–>不推荐

如果你的list里存的比较复杂,是一个List<Map<String,Object>>格式的情况,最无奈之举就是这种方法
主要操作是将同一个list用两层for循环配合.equals()方法,有相同的就用remove()方法剔除掉,然后得到一个没有重复数据的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);}}}}//得到最新移除重复元素的listreturn list;
} 


http://chatgpt.dhexx.cn/article/MjoOf6SF.shtml

相关文章

子图是什么

子图和真子图 设 G <V, E>, <, >是两个图(同为无向,或同为有向图). 若 V 且 E, 则称 为 G 的子图, G 为 的母图, 记作 G 若 V 或 E, 称 为 G 的真子图. 生成子图 若 G 且 V , 则称 为 G 的生成子图 两个导出子图 设 V 且 &#xff08;空集&a…

latex绘制子图,并为子图添加

如下代码所示&#xff1a; 通过\subfigure绘制子图&#xff0c;\centering使图片居中&#xff0c;可以直接在子图中为为图片添加标注&#xff0c;如代码中的{\scriptsize{误差均值}}&#xff0c;该命令表示在子图上面添加标注。有时需要同时在子图的左边也添加竖排标注&#xf…

Python Matplotlib 子图

目录 1、绘制多个子图 2、绘图在指定的子图上 3、subplots命令&#xff1a;快速生成多个子图框架 3.1 快速布局 3.2 画一个图形 3.3 多个图形共用一个轴 3.4 与seaborn联合使用 3.5 使用数组方式指定子图 3.6 嵌套图 在matplotlib中&#xff0c;所有的绘图操作实际上都是以…

Matplotlib多子图绘图后保存单个子图

import numpy as np import matplotlib.pyplot as plt# 用于单独保存子图的函数 def save_subfig(fig,ax,save_path,fig_name):bbox ax.get_tightbbox(fig.canvas.get_renderer()).expanded(1.02, 1.02)extent bbox.transformed(fig.dpi_scale_trans.inverted())fig.savefig(…

Matplotlib子图

子图 **有时候我们需要从多个角度进行数据的比较、分析&#xff0c;因此就需要用到子图。**子图的本质是在一个较大的图形中同时放置一组较小的坐标轴&#xff0c;布局形式可以多种多样&#xff0c;不拘泥于我们在第五集中举的那种网格图的形式。 一般化的子图 我们先进行一…

latex生成子图及并列图

latex生成子图及并列图 \usepackage{graphicx}%插入图片 \usepackage{subfigure} %子图 子图 代码 \begin{figure} \centering \subfigure[Average total cost with different schemes.]{ \includegraphics[width3in]{V9-1-vary-S} } \subfigure[Average time delay with …

【数据分析之道-Matplotlib(三)】Matplotlib 绘制子图

文章目录 专栏导读1、前言2、subplot()函数2.1创建一个包含 2x2 的子图布局&#xff0c;并在每个子图中绘制不同的图形2.2创建一个包含 1x3 的子图布局&#xff0c;并绘制三种不同类型的图形2.3创建一个包含 2 行 1 列的子图布局&#xff0c;绘制散点图和柱状图 3、subplots()函…

matplotlib 基础_子图创建

目录 创建Axes方法1 、 add_subplot 函数&#xff1a;快速创建1.1 设置不等尺寸的子图 2、add_axes 函数&#xff1a;自由设置子图的位置、大小3、指定子图空间&#xff1a;当子图大小成倍数时 一张图理解matplotlib Figure 和 Axes Figure 就是图片&#xff0c;一个完整的图片…

plt.plot画子图时,子图变形,调整子图大小

在画图时候遇到的记录一下 希望可以帮到遇到相同问题的伙伴儿~~ 本来是这样&#xff1a; 本来代码&#xff1a; plt.subplot(1, 2, 1)plt.rcParams[font.sans-serif] [SimHei]plt.rcParams[axes.unicode_minus] Falseplt.rcParams[figure.dpi] 1080plt.rcParams[figure.fi…

关于图论中导出子图的概念

关于图论中导出子图的概念 1、导出子图 A subgraph H is called an induced subgraph of X if for any a , b ∈ E ( H ) a,b \in E(H) a,b∈E(H) if and only if a , b ∈ E ( X ) a,b \in E(X) a,b∈E(X). 2、点导出子图 设S是V(G)的子集&#xff0c;以S为点集&#xf…

极大连通子图与极小连通子图

无向图 连通图&#xff1a; 在无向图中&#xff0c;若从定点V1到V2有路径&#xff0c;则称顶点V1和V2是连通的。如果图中任意一对顶点都是连通的&#xff0c;则称此图是连通图。&#xff08;连通的无向图&#xff09;极大连通子图&#xff1a; 1.连通图只有一个极大连通子图&a…

python数据可视化玩转Matplotlib subplot子图操作,四个子图(一包四),三个子图,子图拉伸

目录 一、创建子图 1.1 下图是绘制的子图&#xff1a; 1.2 代码释义&#xff1a; 二、绘制子图 2.1 代码引入 2.2 图形绘制 三、子图布局 3.1 子图布局说明 四、子图大小 4.1 子图大小调整 五、子图间距 5.1 子图代码调整 六、子图位置 6.1 代码引入 6.2 完整代码…

极大连通子图与极小连通子图(带图讲解)

因为本人对于这一块知识存在疑惑&#xff0c;在学习了相关知识后将自己的理解分享给大家&#xff0c;如有错误&#xff0c;欢迎纠正。 首先我们先明确一下&#xff0c;极小连通子图与极大连通子图是在无向图中进行讨论的。 极大强连通子图是在有向图中进行讨论的&#xff0c;不…

Python 调整子图大小、位置【plt.axes()自定义子图】

效果图&#xff1a; plt.axes()绘图结果 上图一共三个子图&#xff0c;两个横向子图对齐右侧纵向长图。 本来想用plt.subplot()函数画&#xff0c;结果找了半天都是下图这种结果&#xff1a; 只能合并列&#xff0c;不能合并行 plt.subplot()绘图结果 因此&#xff0c;我放…

子图的概念

设G(V,E)为一个图,H(V’,E’)也是一个 图,称H为G的一个子图(subgraph),如果 ,并且对任意的边euv∈E’必须有u,v∈V’,记为 , 此时也称G为H的母图(super graph). 设H(V’,E’)为G(V,E)的一个子图,称H为G的生成(支撑)子图(spanning subgraph),如果V’V. 设G(V,E)是一个图,,构造一…

最大完全子图和极大连通子图

最近学习图论的一串小结之一 完全图&完全子图&最大完全子图 完全图&#xff1a;任意两点都恰有一条边相连的图(任意两点都相邻)。 完全子图&#xff1a;满足任意两点都恰有一条边相连的子图&#xff0c;也叫团。 最大完全子图&#xff1a;所有完全子图中顶点数最大…

子图,生成子图和导出子图

所有的顶点和边都属于图G的图称为G的子图。含有G的所有顶点的子图称为G的生成子图。 设V1是V的一个非空子集&#xff0c;以V1为顶点集&#xff0c;以两端点均在V1中的边的全体为边集的子图称为G的导出子图&#xff0c;记作G[V1]。导出子图G[V\V1]记为G-V1&#xff0c;它是从G中…

子图、生成子图、导出子图和主子图

所有的顶点和边都属于图G的图称为G的子图。含有G的所有顶点的子图称为G的生成子图。 设V1是V的一个非空子集&#xff0c;以V1为顶点集&#xff0c;以两端点均在V1中的边的全体为边集的子图称为G的导出子图&#xff0c;记作G[V1]。导出子图G[V\V1]记为G-V1&#xff0c;它是从…

子图,生成子图(Spanning Subgraph),导出子图(Induced Subgraph)的定义

首先给出一些定义。原图G用G (V, E)表示&#xff0c;V是G中的所有顶点的集合&#xff1b;E是G中所有边的集合。 子图 定义&#xff1a;子图G’中所有的顶点和边均包含于原图G。即E’∈E&#xff0c;并且V’∈V。 生成子图&#xff08;Spanning Subgraph&#xff09; 定义&…

图论中的概念(1)——子图、商图与补图

1.子图(subgraph) 设G(V, E)和G¢(V¢, E¢)是两个(有向的或无向的)图。 (1) 若V¢V且E¢ E&#xff0c;则称G¢为G的子图&#xff1b; (2) 若V¢V且 E¢ E&#xff0c;则称G¢为G的真子图(proper-)&#xff1b; (3) 若V¢V且E…