zoukankan      html  css  js  c++  java
  • 几种list排序方法

    package com.lgx.jdk8.part02;
     
    import java.util.*;
    import java.util.stream.Collectors;
     
    /**
     * Comparator比较器的使用
     */
    public class TestComparator {
        public static void main(String[] args) {
            List<String> list = Arrays.asList("nice", "to", "meet", "you");
     
            //升序排序,流的写法
            //list.stream().sorted(Comparator.comparing(str -> str)).collect(Collectors.toList()).forEach(System.out::println);
     
            //升序排序,默认写法
            /*Collections.sort(list);
            System.out.println("list = " + list);*/
     
            //自定义排序器,默认写法
            /*Collections.sort(list, (item1, item2) -> item1.length() - item2.length()); //升序
            Collections.sort(list, (item1, item2) -> item2.length() - item1.length());   //降序
            System.out.println("list = " + list);*/
     
            //自定义排序器,Comparator写法
            /*Collections.sort(list, Comparator.comparingInt(str -> str.length()));                       //升序
            Collections.sort(list, Comparator.comparingInt(str -> str.length()).reversed());              //降序,会报错,因为编译器在这里无法推断str的类型为String,而是推断出事一个Objcet
            Collections.sort(list, Comparator.comparingInt((String str) -> str.length()).reversed());*/   //降序,显示的指定一个类型
     
            //自定义排序器,Comparator写法2
            /*Collections.sort(list, Comparator.comparingInt(String::length));           //升序
            Collections.sort(list, Comparator.comparingInt(String::length).reversed());  //降序
            System.out.println("list = " + list);*/
     
            //直接调用list的排序方法,Collections.sort()本质还是调用list.sort方法
            /*list.sort(Comparator.comparingInt(String::length));             //升序
            list.sort(Comparator.comparingInt(String::length).reversed());    //降序*/
     
            /**两层排序:先按照长度排序,再按照字符串顺序**/
            //Collections.sort(list, Comparator.comparingInt(String::length).thenComparing(String.CASE_INSENSITIVE_ORDER));   //不区分大小写的排序
            //Collections.sort(list, Comparator.comparingInt(String::length).thenComparing(String::compareTo));
            //Collections.sort(list, Comparator.comparingInt(String::length).thenComparing((item1, item2) -> item1.toLowerCase().compareTo(item2.toLowerCase())));
            //Collections.sort(list, Comparator.comparingInt(String::length).thenComparing(Comparator.comparing(String::toLowerCase)));
            //Collections.sort(list, Comparator.comparingInt(String::length).thenComparing(Comparator.comparing(String::toLowerCase, Comparator.reverseOrder())));
            Collections.sort(list, Comparator.comparingInt(String::length).thenComparing(Comparator.comparing(String::toLowerCase, Comparator.reverseOrder())).
                    thenComparing(Comparator.reverseOrder()));//和上一个结果是一样的,因为已经排好序了,最后一个就不起作用了
            System.out.println("list = " + list);
     
        }
    }
  • 相关阅读:
    【ZOJ3195】Design the City-LCA算法
    【ZOJ3195】Design the City-LCA算法
    【POJ1330】Nearest Common Ancestors-LCA算法
    【POJ1330】Nearest Common Ancestors-LCA算法
    【POJ3237】Tree-树链剖分
    【POJ3237】Tree-树链剖分
    【SPOJ375】Query on a tree-树链剖分
    perl 回调必须是函数引用
    运行复制的ZooKeeper 部署
    运行复制的ZooKeeper 部署
  • 原文地址:https://www.cnblogs.com/assasion/p/9838738.html
Copyright © 2011-2022 走看看