集合去重的几种方法_田恬甜的博客-程序员秘密

技术标签: 集合  java  

参考:https://mp.weixin.qq.com/s/94vQ_9jWaLZAXmWi_HQEOg

方法1:contains判断去重(有序)

要进行数据去重,我们首先想到的是新建一个集合,然后循环原来的集合,每次循环判断原集合中的循环项,如果当前循环的数据,没有在新集合中存在就插入,已经存在了就舍弃,这样当循环执行完,我们就得到了一个没有重复元素的集合了,实现代码如下:

public class ListDistinctExample {
    
    public static void main(String[] args) {
    
        List<Integer> list = new ArrayList<Integer>() {
    {
    
            add(1);
            add(3);
            add(5);
            add(2);
            add(1);
            add(3);
            add(7);
            add(2);
        }};
        System.out.println("原集合:" + list);
        method(list);
    }
    /**
     * 自定义去重
     * @param list
     */
    public static void method(List<Integer> list) {
    
        // 新集合
        List<Integer> newList = new ArrayList<>(list.size());
        list.forEach(i -> {
    
            if (!newList.contains(i)) {
     // 如果新集合中不存在则插入
                newList.add(i);
            }
        });
        System.out.println("去重集合:" + newList);
    }
}

以上程序执行的结果,如下所示:图片此方法的优点的:理解起来比较简单,并且最终得到的集合也是有序的,这里的有序指的是新集合的排列顺序和原集合的顺序是一致的;但缺点是实现代码有点多,不够简洁优雅。

方法2:迭代器去重(无序)

自定义 List 去重,除了上面的新建集合之外,我们也可以使用迭代器循环判断每一项数据,如果当前循环的数据,在集合中存在两份或两份以上,就将当前的元素删除掉,这样循环完之后,也可以得到一个没有重复数据的集合,实现代码如下:

public class ListDistinctExample {
    
    public static void main(String[] args) {
    
        List<Integer> list = new ArrayList<Integer>() {
    {
    
            add(1);
            add(3);
            add(5);
            add(2);
            add(1);
            add(3);
            add(7);
            add(2);
        }};
        System.out.println("原集合:" + list);
        method_1(list);
    }

    /**
     * 使用迭代器去重
     * @param list
     */
    public static void method_1(List<Integer> list) {
    
        Iterator<Integer> iterator = list.iterator();
        while (iterator.hasNext()) {
    
            // 获取循环的值
            Integer item = iterator.next();
            // 如果存在两个相同的值
            if (list.indexOf(item) != list.lastIndexOf(item)) {
    
                // 移除最后那个相同的值
                iterator.remove();
            }
        }
        System.out.println("去重集合:" + list);
    }
}

以上程序执行的结果,如下所示:图片此方法的实现比上一种方法的实现代码要少一些,并且不需要新建集合,但此方法得到的新集合是无序的,也就是新集合的排列顺序和原集合不一致,因此也不是最优的解决方案。

方法3:HashSet去重(无序)

我们知道 HashSet 天生具备“去重”的特性,那我们只需要将 List 集合转换成 HashSet 集合就可以了,实现代码如下:

public class ListDistinctExample {
    
    public static void main(String[] args) {
    
        List<Integer> list = new ArrayList<Integer>() {
    {
    
            add(1);
            add(3);
            add(5);
            add(2);
            add(1);
            add(3);
            add(7);
            add(2);
        }};
        System.out.println("原集合:" + list);
        method_2(list);
    }

    /**
     * 使用 HashSet 去重
     * @param list
     */
    public static void method_2(List<Integer> list) {
    
        HashSet<Integer> set = new HashSet<>(list);
        System.out.println("去重集合:" + set);
    }
}

以上程序执行的结果,如下所示:图片此方法的实现代码较为简洁,但缺点是 HashSet 会自动排序,这样新集合的数据排序就和原集合不一致了,如果对集合的顺序有要求,那么此方法也不能满足当前需求。

方法4:LinkedHashSet去重(有序)

既然 HashSet 会自动排序不能满足需求,那就使用 LinkedHashSet,它既能去重又能保证集合的顺序,实现代码如下:

public class ListDistinctExample {
    
    public static void main(String[] args) {
    
        List<Integer> list = new ArrayList<Integer>() {
    {
    
            add(1);
            add(3);
            add(5);
            add(2);
            add(1);
            add(3);
            add(7);
            add(2);
        }};
        System.out.println("原集合:" + list);
        method_3(list);
    }

    /**
     * 使用 LinkedHashSet 去重
     * @param list
     */
    public static void method_3(List<Integer> list) {
    
        LinkedHashSet<Integer> set = new LinkedHashSet<>(list);
        System.out.println("去重集合:" + set);
    }
}

以上程序执行的结果,如下所示:图片从上述代码和执行结果可以看出,LinkedHashSet 是到目前为止,实现比较简单,且最终生成的新集合与原集合顺序保持一致的实现方法,是我们可以考虑使用的一种去重方法。

方法5:TreeSet去重(无序)

除了以上的 Set 集合之外,我们还可以使用 TreeSet 集合来实现去重功能,实现代码如下:

public class ListDistinctExample {
    
    public static void main(String[] args) {
    
        List<Integer> list = new ArrayList<Integer>() {
    {
    
            add(1);
            add(3);
            add(5);
            add(2);
            add(1);
            add(3);
            add(7);
            add(2);
        }};
        System.out.println("原集合:" + list);
        method_4(list);
    }

    /**
     * 使用 TreeSet 去重(无序)
     * @param list
     */
    public static void method_4(List<Integer> list) {
    
        TreeSet<Integer> set = new TreeSet<>(list);
        System.out.println("去重集合:" + set);
    }
}

以上程序执行的结果,TreeSet 有着和 HashSet 一样的问题,会自动进行自然排序

方法6:Stream去重(有序)

JDK 8 为我们带来了一个非常实用的方法 Stream,使用它可以实现很多功能,比如下面的去重功能:

public class ListDistinctExample {
    
    public static void main(String[] args) {
    
        List<Integer> list = new ArrayList<Integer>() {
    {
    
            add(1);
            add(3);
            add(5);
            add(2);
            add(1);
            add(3);
            add(7);
            add(2);
        }};
        System.out.println("原集合:" + list);
        method_5(list);
    }

    /**
     * 使用 Stream 去重
     * @param list
     */
    public static void method_5(List<Integer> list) {
    
        list = list.stream().distinct().collect(Collectors.toList());
        System.out.println("去重集合:" + list);
    }
}

以上程序执行的结果,如下所示:图片Stream 实现去重功能和其他方法不同的是,它不用新创建集合,使用自身接收一个去重的结果就可以了,并且实现代码也很简洁,并且去重后的集合顺序也和原集合的顺序保持一致,是我们最优先考虑的去重方法。

总结

本文我们介绍了 6 种集合去重的方法,其中实现最简洁,且去重之后的顺序能和原集合保持一致的实现方法,只有两种:LinkedHashSet 去重和 Stream 去重,而后一种去重方法无需借助新集合,是我们优先考虑的去重方法。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Tjy20/article/details/122884299

智能推荐

Linux(Ubuntu)系统安装Python_乌班图安装python_睿科知识云的博客-程序员秘密

Linux(Ubuntu)系统安装PythonLinux 系统是为编程而生的,因此绝大多数的 Linux 发行版(Ubuntu、CentOS 等)都默认自带了 Python。有的 Linux 发行版甚至还会自带两个版本的 Python,例如最新版的 Ubuntu 会自带 Python 2.x 和 Python 3.x。打开 Linux 发行版内置的终端(Terminal),输入python命令就可以检测是否安装了 Python,以及安装了哪个版本,如下所示:[[email protected]

Paint的用法总结_weixin_33737134的博客-程序员秘密

Paint的用法总结上一期在总结canvas的用法时候谈到绘制需要的四个组件:一个保存像素的Bitmap,一个主持绘画操作的Canvas(往Bitmap写东西),一个绘制的基本元素(例如Rect,Path,Text,Btimap),一支画笔(用来描述绘画的颜色与风格)。在上一期文章《关于Canvas的用法,这些都只是基操》里总结了canvas的一些用法,那么这次就来总结一下画笔Paint的一些...

php.ini中display_startup_errors=on显示的都是什么错误【500】?_luogan129的博客-程序员秘密

php.ini中display_startup_errors=on显示的都是什么错误?https://segmentfault.com/q/1010000005952475/a-1020000005953624

swiper vue 切换到指定_vue中swiper的使用(轮播失效)_何新彪的博客-程序员秘密

在使用vue写swiper轮播图的时候,有时会发生轮播图不生效的问题,这是因为页面中JS执行的顺序问题,这时swiper中的Observer(监视器)就派上用场了;observer:true, // 修改swiper自己或子元素时,自动初始化swiperobserveParents:true, // 修改swiper的父元素时,自动初始化swiper在swiper中加上这是就可以进行动态监听了,不...

Chrome插件开发_weixin_34341229的博客-程序员秘密

2019独角兽企业重金招聘Python工程师标准&gt;&gt;&gt; ...

Java远程调试 java -Xdebug各参数说明_xrunjdwp参数_life1024的博客-程序员秘密

用处:如果用命令执行某个项目中包含某个xxx.jar,然后有问题,你想去调试。那么你可以在命令启动的时候设置监听的端口12345,然后在编辑工具中如eclipse ,debugxxx.jar的原码并连接到 12345,然后请求项目时,就会在元源码中调试。首先,JAVA自身支持调试功能,并提供了一个简单的调试工具--JDB,类似于功能强大的GDB,JDB也是一个字符界面的调试

随便推点

JDBC数据库的连接和数据库的操作_diaogu9242的博客-程序员秘密

1. Java数据库的连接及操作1)数据库连接工具类 1 /** 2 * 数据库连接工具类 3 * @author vanguard 4 * 5 */ 6 public class JDBCUtils { 7 8 private static Connection conn; 9 private static ...

android java层 binder,Android java层binder解析1_13858573656的博客-程序员秘密

下面直接从ServiceManager的addService看起ServiceManager.javapublic static void addService(String name, IBinder service) {try {getIServiceManager().addService(name, service, false);} catch (RemoteException e) {...

vue-cli3 按需引入 element-ui 报错_NorthHarbor45的博客-程序员秘密

vue-cli3 按需引入 element-ui 报错报错信息:Cannot find module 'babel-preset-es2015' from ....解决办法:安装最新的 Babel 编译插件:@babel/preset-env修改 babel.config.js 文件(也可创建 .babelrc 文件)module.exports = { "pres...

催收策略_番茄风控的博客-程序员秘密

关注公众号“番茄风控大数据”,获取更多数据分析与风控大数据的实用干货。&nbsp;这篇文章主要是接上面一篇文章的:金融风控干货篇:失联模型在上篇文章里,我们说,在催收模块里,开发的催收模型往往是不止一个模型的,一般我们会通过不同的评分卡去区分不同的风险。比如我们经常强调的滚动率模型,会用到好几个模型一起叠加来使用,我们有时不仅使用两个模型来叠加,还会使用3个甚至4个模型叠加使用。下面我们使...

将整个工程所有代码的编码由GBK转为UTF-8_转换整个工程编码_蝎子莱布莱的博客-程序员秘密

最近突然遇到要将整个工程Java代码的编码由GBK改成UTF-8的需求,所以写了下段代码,供小伙伴们参考。需要一个jar包依赖://本人版本是2.5commons-ioimport java.io.File;import java.util.Collection;import org.apache.commons.io.FileUtils;/** * @Clas...

vue实战开发002:局域网中访问vue-cli项目_内网学习vue_ProgramNotes的博客-程序员秘密

项目准备上线了,后期交给另一个团队负责,在部署服务器前人家要先了解下我们的项目情况,所以需要登录,由于是内网环境,所以对方可以直接访问我的电脑ip来访问我的本地项目,但是在开发时我们设置的是localhost也就是127.0.0.1访问本地项目,其他人想访问时无法访问的,这时我们就需要对vue进行下配置了。先找到自己的ip,运行中输出cmd,然后执行ipconfig/all就可以...

推荐文章

热门文章

相关标签