zoukankan      html  css  js  c++  java
  • [javaSE] 集合工具类(Collections-sort)

    java为我们提供了一个集合的工具类,方便我们对集合进行操作,里面的方法都是静态方法。

    Collections.sort()方法,参数:List<T>集合对象,这个对象带着泛型,是为了保证集合中的元素具备可比较性,因此这个返回值的泛型就会特殊点, <T extends Comparable <? super T>>

    默认排序字符串,是按照字母的排列顺序

    如果是中文,默认是按照ascii编码进行排序的

    自定义一个比较器,实现按照字符串的长度进行排序

    定义一个类StrComparator实现Comparator

    实现方法compare(),参数:

    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.Comparator;
    import java.util.List;
    
    
    public class CollectionsDemo {
    
        /**
         * @param args
         */
        public static void main(String[] args) {
            List<String> list=new ArrayList<String>();
            list.add("aaa");
            list.add("ccc");
            list.add("bbb");
            list.add("eee");
            System.out.println(list);//输出 [aaa, ccc, bbb, eee]
            Collections.sort(list);
            System.out.println(list);//输出 [aaa, bbb, ccc, eee]
            
            List<String> list2=new ArrayList<String>();
            list2.add("陶");
            list2.add("士");
            list2.add("涵");
            System.out.println(list2);//输出 [陶, 士, 涵]
            Collections.sort(list2);
            System.out.println(list2);//输出 [士, 涵, 陶]
            
            List<String> list3=new ArrayList<String>();
            list3.add("aaa");
            list3.add("c");
            list3.add("bb");
            list3.add("eeee");
            System.out.println(list3);//输出 [aaa, c, bb, eeee]
            Collections.sort(list3,new StrComparator());
            System.out.println(list3);//输出 [c, bb, aaa, eeee]
            
        }
    
    }
    /**
     * 自定义比较器
     * @author taoshihan
     *
     */
    class StrComparator implements Comparator<String>{
    
        @Override
        public int compare(String o1, String o2) {
            if(o1.length()>o2.length()){
                return 1;
            }else if(o1.length()<o2.length()){
                return -1;
            }
            return o1.compareTo(o2);
        }
        
    }

    PHP版:

    <?php
    $list=array("aaa","ccc","bbb","eee");
    sort($list);
    print_r($list);//输出 Array ( [0] => aaa [1] => bbb [2] => ccc [3] => eee )
    
    $list2=array("陶","士","涵");
    sort($list2);
    print_r($list2);//输出 Array ( [0] => 士 [1] => 涵 [2] => 陶 )
    
    $list3=array("aaa","c","bb","eeee");
    usort($list3,"StrComparator");
    print_r($list3);//输出 Array ( [0] => c [1] => bb [2] => aaa [3] => eeee )
    
    //自定义的比较函数
    function StrComparator($a,$b){
        if(strlen($a)>strlen($b)){
            return 1;
        }elseif(strlen($a)<strlen($b)){
            return -1;
        }
        return 0;
    }
  • 相关阅读:
    7,C++ public, protected, private 继承的区别
    6,又一道经典的微软题
    5,一道经典的微软程序题
    33. Search in Rotated Sorted Array
    198,House Robber
    4,二维数组中指针的问题
    剑指offer——stack与queue的互相实现
    3,C语言文件读写
    2,虚函数
    剑指offer——已知二叉树的先序和中序排列,重构二叉树
  • 原文地址:https://www.cnblogs.com/taoshihan/p/5536365.html
Copyright © 2011-2022 走看看