Java Comparator排序

简介: ArrayList mItems = new ArrayList(); for (int i = 0; i < 10; i++) { mItems.
        ArrayList<Integer> mItems = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            mItems.add((int) (Math.random() * 10));
        }
        Logger.d("源数据:" + mItems);

        ArrayList<Integer> mItems2 = new ArrayList<>();
        mItems2.addAll(mItems);

        Collections.sort(mItems, new Comparator<Integer>() {
            // 返回值为int类型。
            // 大于0表示顺序(递增)【o1 > o2】,小于0表示逆序(递减)【o1 < o2】。
            @Override
            public int compare(Integer o1, Integer o2) {
                if (o1 > o2) {
                    return 1;
                } else {
                    return -1;
                }
            }
        });
        Logger.d("排序后(顺序):" + mItems);

        Collections.sort(mItems2, new Comparator<Integer>() {
            // 返回值为int类型。
            // 大于0表示顺序(递增),小于0表示逆序(递减)。
            // 0,相等。
            @Override
            public int compare(Integer o1, Integer o2) {
                if (o1 > o2) {
                    return -1;
                } else {
                    return 1;
                }
            }
        });
        Logger.d("排序后(逆序):" + mItems2);


输出:

源数据:[4, 6, 9, 1, 2, 5, 0, 5, 8, 5]
排序后(顺序):[0, 1, 2, 4, 5, 5, 5, 6, 8, 9]
排序后(逆序):[9, 8, 6, 5, 5, 5, 4, 2, 1, 0]


相关文章
|
3月前
|
存储 搜索推荐 算法
【用Java学习数据结构系列】七大排序要悄咪咪的学(直接插入,希尔,归并,选择,堆排,冒泡,快排)以及计数排序(非比较排序)
【用Java学习数据结构系列】七大排序要悄咪咪的学(直接插入,希尔,归并,选择,堆排,冒泡,快排)以及计数排序(非比较排序)
34 1
|
5月前
|
Java API
|
6月前
|
Java API 存储
Java如何对List进行排序?
【7月更文挑战第26天】
278 9
Java如何对List进行排序?
|
5月前
|
存储 Java
Java中ArrayList 元素的排序
本文提供了Java中根据`ArrayList`元素的某个属性进行排序的示例代码,包括实现`Comparable`接口和重载`compareTo`方法,然后使用`Collections.sort`方法进行排序。
|
5月前
|
存储 Java API
【Java高手必备】揭秘!如何优雅地对List进行排序?掌握这几种技巧,让你的代码瞬间高大上!
【8月更文挑战第23天】本文深入探讨了Java中对List集合进行排序的各种方法,包括使用Collections.sort()、自定义Comparator以及Java 8的Stream API。通过示例代码展示了不同情况下如何选择合适的方法:从简单的整数排序到自定义类对象的排序,再到利用Comparator指定特殊排序规则,最后介绍了Stream API在排序操作中的简洁应用。理解这些技术的区别与应用场景有助于提高编程效率。
137 4
|
5月前
|
搜索推荐 算法 Java
堆排序实战:轻松实现高效排序,附详细Java代码
嗨,大家好!我是小米,一名热爱技术分享的程序员。今天要带大家了解堆排序——一种基于二叉堆的数据结构,具有O(n log n)时间复杂度的选择排序算法。堆排序分为构建大顶堆和排序两个阶段:先建堆使根节点为最大值,再通过交换根节点与末尾节点并调整堆来逐步排序。它稳定高效,空间复杂度仅O(1),适合对稳定性要求高的场合。虽然不如快速排序快,但在避免递归和节省空间方面有优势。一起动手实现吧!如果有任何疑问,欢迎留言交流!
101 2
|
5月前
|
存储 Java
|
5月前
|
Java 容器
07 Java数组与数组操作(定义+遍历+排序+增删改查)(上)
07 Java数组与数组操作(定义+遍历+排序+增删改查)
66 8
|
5月前
|
存储 Java API
07 Java数组与数组操作(定义+遍历+排序+增删改查)(下)
07 Java数组与数组操作(定义+遍历+排序+增删改查)
46 4
|
5月前
|
存储 Java