栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

集合的排序

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

集合的排序

集合的排序
* 集合的工具类java.util.Collections下有一个静态方法:sort,可以对List集合进行自然排序(从小到大)
新建一个随机数的数组:

Random random = new Random();
List list = new ArrayList<>();
for (int i =0;i<10;i++){
   list.add(random.nextInt(100));
}

        System.out.println(list); //排序前队列
        Collections.sort(list); //排序的关键语句
        System.out.println(list); //排序后队列

排序自定义类型元素

       新建一个集合用于示例:

         List list = new ArrayList<>();
        list.add(new Point(5,6));
        list.add(new Point(25,54));
        list.add(new Point(1,16));
        list.add(new Point(2,9));
        list.add(new Point(7,3));
        list.add(new Point(43,4));
        list.add(new Point(12,45));
        System.out.println(list);

方法语句:Collections.sort(List list);
该方法要求List集合中的元素必须是可比较的,判定是否可比较的标准为元素是否实现了接口
 java.util.Comparable
当我们使用一个API时,该API反过来要求我们为其修改代码,那么这个API就对我们的程序有侵入性,侵入性不利于程序后期维护,应当尽量避免   
 单独定义比较器(定义Point元素的比较规则)
        compare方法用于定义o1和o2比较大小的规则,并用返回值表达大小关系.
                返回值实现的要求:
                如果返回值>0则表达的是o1>o2
                如果返回值<0则表达的是o1                 如果返回值=0则表达的是o1=o2 

 Comparator c = new Comparator() {
        public int compare(Point o1, Point o2) {
            int olen1 = o1.getX()*o1.getX()+o1.getY()*o1.getY();
            int olen2 = o2.getX()*o2.getX()+o2.getY()*o2.getY();
                return olen1-olen2;//升序
            return olen2-olen1;//反过来减就是降序(从大到小)
        }
    };

 简略写法:

Collections.sort(list,(o1,o2)->
                o1.getX()*o1.getX()+o1.getY()*o1.getY()-
                        o2.getX()*o2.getX()-o2.getY()*o2.getY()
        );

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/1039921.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号