zoukankan      html  css  js  c++  java
  • java list集合去重复

    利用set针对list去重复是个好办法,记录下下。

    只是针对list中的object进行了去重复的处理,如果是要依据object中的某个值进行去重复处理还是达不到目标。这里仅做依据set去重复的一个记录,在实际项目中并没有这么简单的结构等着我们去重复。

    大家有好的脑洞,一起分享下。

    package ss;
    
    import java.util.*;
    /**
     * 针对list去重复处理
     * 
     * @author zhangss 
     * @version 1.0
     * */
    public class ListDistinct <T>{
        /**
         * 通过set去重, 不打乱原有list的顺序
         *       list中相同的对象会被去重复
         *      
         * @param List<T> list
         * @return List<T>
         * */
        public List<T> distinctBySetOrder(List<T> list){
            Set<T> set = new  HashSet<T>(); 
            List<T> newList = new  ArrayList<T>(); 
            for (T t :list) {
               if(set.add(t)){
                   newList.add(t);
               }
            }
            return newList;
        }
        /**
         * 通过set去重, 顺序可能会乱
         *       list中相同的对象会被去重复
         *      
         * @param List<T> list
         * @return List<T>
         * */
        public List<T> distinctBySet(List<T> list){
            return new ArrayList<T>(new HashSet<T>(list));
        }
        /**
         * 通过遍历判断后将赋予新的集合
         * 
         * @param List<T>
         * @reutrn List<T>
         * */
        public List<T> distinctByANewList(List<T> list){
            List<T> newList = new  ArrayList<T>(); 
            for(T t : list){
                if(!newList.contains(t)){
                    newList.add(t);
                }
            }
            return newList;
        }
        public static void main(String[] args){
            ListDistinct<String> ld = new ListDistinct<String>();
            List<String> list  =   new  ArrayList<String>(); 
            list.add("zhang");
            list.add("zhang");
            list.add("ss");
            list.add("ss");
            list.add("2s");
            list.add("s3");
            System.out.println("1:" + ld.distinctBySetOrder(list).toString());
            System.out.println("2:" + ld.distinctBySet(list).toString());
            System.out.println("3:" + ld.distinctByANewList(list).toString());
        }
    }
  • 相关阅读:
    数位DP
    组合
    卢卡斯Lucas&扩展卢卡斯
    [HNOI2014]道路堵塞
    [模板]三维凸包(无讲解)
    [CF526G]Spiders Evil Plan
    [CCPC2019 ONLINE]H Fishing Master
    [CCPC2019 ONLINE]E huntian oy
    [CF1037H]Security
    [CF1037F]Maximum Reduction
  • 原文地址:https://www.cnblogs.com/zsslll/p/6285374.html
Copyright © 2011-2022 走看看