zoukankan      html  css  js  c++  java
  • Java,List操作技巧

    Java List 操作技巧

    去重

    借助Set去重 , 效率要好一些 , 算是以空间换时间

    List ori = Arrays.asList(2,1,4,5,3,2,1);
    Set unique = new HashSet(ori);
    List unique_list = new ArrayList(unique);
    

    排序

    自身排序

    如果是基础类型, JDK里都已经实现了排序, 直接使用就可以了.

    List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
    ori.sort(new Comparator<Integer>() {
                @Override
                public int compare(Integer o1, Integer o2) {
                    return o1.compare(o2); //正序
                    //return o2.compare(o1); //倒序
                }
            }); 
    --------
    //简洁方式
    ori.sort(Integer::compareTo); //正序
    ori.sort(Comparator.reverseOrder()); //倒序
    

    参考排序

    给定一个顺序 , 参考这个顺序排序

    例如: 有个顺序 2,1,4,5,3, 要列表按这个顺序排列

    List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
    List<Integer> target = Arrays.asList(4,5,3,1,2); //要排序的List
    target.sort(new Comparator<Integer>() {
                @Override
                public int compare(Integer o1, Integer o2) {
                    return Integer.compare(ori.indexOf(o1),ori.indexOf(o2));
                }
            });
    
    System.out.println(target); // 结果 2,1,4,5,3
    

    Java 8 以上的话, 还可以用简单和表达式 , 省不少代码

    List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
    List<Integer> target = Arrays.asList(4,5,3,1,2); //要排序的List
    target.sort(Comparator.comparingInt(s -> ori.indexOf(s)));
    
    System.out.println(target); // 结果 2,1,4,5,3
    

    当然也可以是按Bean的字段排序 .

    List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
    List<ID> target = Arrays.asList(4,5,3,1,2); //要排序的List
    target.sort(Comparator.comparingInt(s -> ori.indexOf(s.getId())));
    
    System.out.println(target); // 结果 2,1,4,5,3
    

    指定元素排到最前或最后

    同样的顺序 2,1,4,5,3 , 想把 4 拓到最前面 .

    List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
    ori.sort(((o1, o2) -> o1 == 4L ? 1 : -1); // 4 往前移, 其他都往后移
    

    如果文章有帮助到您,请点个赞,您的反馈会让我感到文章是有价值的

  • 相关阅读:
    IDEA使用笔记
    面试题整理
    java中的hashCode()方法
    动态规划算法实现部分——0/1背包问题
    算法课堂笔记6—近似算法
    Photoshop CC 2015
    unity学习笔记1--Space Shooter
    转载---sql之left join、right join、inner join的区别
    java连接Fastdfs图片服务器上传失败的解决方法
    Eclipse使用笔记
  • 原文地址:https://www.cnblogs.com/ElEGenT/p/13438664.html
Copyright © 2011-2022 走看看