集合的排序

1.集合的工具类java.util.Collections下有一个静态方法:sort,可以对List集合进行自然排序(从小到大)但对于sort方法而言,它能比较的是要求可以直接进行比较的类型,所以如果比较的内容无法直接比较需要单独定义比较器 定义元素之间的比较规则 

public class SortListDemo2 {
    public static void main(String[] args) {
        List<Point> list = new ArrayList<>();
        list.add(new Point(5,6));
        list.add(new Point(13,87));
        list.add(new Point(55,35));
        list.add(new Point(9,4));
        list.add(new Point(2,1));
        list.add(new Point(99,88));
        System.out.println(list);
        /*
            Collections.sort(List list)
            该方法要求List集合中的元素必须是可比较的.判定是否课比较的标准为元素是否实现了接口:
            java.util.Comparable

            当我们使用一个API时,该API反过来要求我们为其修改代码,那么这个API就对我们的程序有侵入性.
            侵入性不利于程序后期维护,应当尽量避免.

            compare:比较
         */
//        Collections.sort(list);

        //单独定义比较器(定义Point元素的比较规则),可以采用lambda来对定义器进行缩减
//        Comparator<Point> c = new Comparator<Point>() {
//            /*
//                compare方法用于定义o1和o2比较大小的规则,并用返回值表达大小关系.
//                返回值实现的要求:
//                如果返回值>0则表达的是o1>o2
//                如果返回值<0则表达的是o1<o2
//                如果返回值=0则表达的是o1=o2
//             */

//            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,c);


//        Collections.sort(list,new Comparator<Point>() {
//            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;//升序
//            }
//        });

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

        System.out.println(list);
    }
}

二、在list中字符串之间比较的规则为 按照字母的大小和字母的先后顺序进行比较。 当字符串中为其他韩文字时 可以设置一个比较器

public class SortListDemo3 {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
//        list.add("jack");
//        list.add("rose");
//        list.add("jerry");
//        list.add("tom");
//        list.add("black");
//        list.add("ada");
        list.add("苍老师");
        list.add("传奇");
        list.add("小泽老师");
        System.out.println(list);
//        Collections.sort(list);
//        Collections.sort(list,(o1,o2)->o1.length()-o2.length());
//        Collections.sort(list, Comparator.comparingInt(String::length));
        /*
            JDK8之后,List集合自身提供了sort方法进行排序,sort方法依然需要传入比较器.
         */
        list.sort((o1, o2) -> o1.length()-o2.length());
        System.out.println(list);
        
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值