我的编程空间,编程开发者的网络收藏夹
学习永远不晚

java中如何对arrayList按数字大小逆序排序

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

java中如何对arrayList按数字大小逆序排序

对arrayList按数字大小逆序排序

对集合排序要用Collections.sort方法,由于默认它是按从小到大的排序的,如果我们需要逆序的,那么就需要实现Comparator接口的compare方法来完成自定义排序。

需要注意Comparator是接口,new Comparator(){} 的作用是new了一个实现接口的匿名类,开发人员需要在匿名类内部(花括号内)实现你那个接口。

代码

public static void main(String[] args) {
        Integer[] nums = {1,5,34,6,8,7,33};
        ArrayList<Integer> numberList = new ArrayList<>();
        Collections.addAll(numberList, nums);

        // 排序前
        System.out.println("逆序前 numberList " + numberList);

        // 排序后
        ArrayList<Integer> copyList = new ArrayList<>(numberList);
        Collections.sort(copyList, new Comparator<Integer>() {
            @Override
            public int compare(Integer num1, Integer num2) {
                if (num1 > num2) {
                    return -1;
                } else {
                    return 1;
                }
            }
        });
        System.out.println("逆序后 copyList " + copyList);
        // 原列表不变
        System.out.println("逆序后 numberList " + numberList);
    }

arrayList实现自定义排序

ArrayList排序使用

ArrayList中存在sort排序方法,只要你实现了Comparator的接口,按照你自己的排序业务进行实现,你只要告诉这个接口按照什么类型进行排序就OK了。这种方式类似于设计模式中的策略模式,把流程划分好,具体的业务逻辑由用户指定

代码实现:

public class ComparatorTest {
    public static void main(String[] args) {
        baseTypeSort();
        referenceTypeSort();

    }

    private static void referenceTypeSort() {
        Person p1 = new Person(10);
        Person p2 = new Person(16);
        Person p3 = new Person(1);
        Person p4 = new Person(8);
        Person p5 = new Person(100);

        List<Person> people = new ArrayList<>();
        people.add(p1);
        people.add(p2);
        people.add(p3);
        people.add(p4);
        people.add(p5);
        System.out.println("排序前:" + people);
        people.sort((o1, o2) -> o2.getAge() - o1.getAge());
        System.out.println("降序:" + people);
        Collections.sort(people, (o1, o2) -> o1.getAge() - o2.getAge());
        System.out.println("升序:" + people);
        people.sort(Comparator.comparing(Person::getAge));
        System.out.println("comparing写法升序:" + people);
        people.sort(Comparator.comparing(Person::getAge).reversed());
        System.out.println("comparing写法降序:" + people);
    }

    private static void baseTypeSort() {
        // 初始化一组数据,这组数据可以是任意对象
        int[] data = {7, 5, 1, 2, 6, 8, 10, 12, 4, 3, 9, 11, 13, 15, 16, 14};
        // 构建成一个集合
        List<Integer> list = new ArrayList<>();
        for (int i = 0; i < data.length; i++) {
            list.add(data[i]);
        }
        System.out.println("排序前:" + list);
        //逆序
        list.sort((o1, o2) -> o2 - o1);
        System.out.println("降序:" + list);
    }
}

由于现在主流jdk都升级到1.8以上,所以使用lamda表达式实现,这里简单介绍一下lamda表达式使用:

  • 以逗号分隔,以()关闭的形参:(Integer m, Integer n)
  • 箭头标记:->
  • 主体部分则是一个单表达式或者声明代码块。
  • 如下是单表达式形式:
(o1, o2) -> o2.getAge() - o1.getAge()

注意点:

  • Java7,list并没有sort方法,请使用Collections.sort(),Collections.sort()传入ArrayList和自己实现Commparator接口的类的对象,实现自定义排序
  • 使用Collections.sort()传入ArrayList和自己实现Commparator接口的类的对象,实现自定义排序
  • 使用List.sort()传入自己实现Commparator接口的类的对象,实现自定义排序
  • Comparator返回值在jdk1.7、jdk1.8里必须是一对相反数,可以使用差值简化写法,正数表示升序,负数表示降序
  • ArrayList中的sort排序是采用归并排序的,当数组中的数据非常大的时候,会采用几次归并来完成排序.具体采用几次归并,会通过相关方法进行计算

原理分析

Collections.sort方法底层就是调用的Arrays.sort方法,而Arrays.sort底层调用了一个非常优秀的工程排序实现算法:TimSort,Timsort是一种结合了归并排序和插入排序的混合算法,由Tim Peters在2002年提出,并且已经成为Python 2.3版本以后内置排序算法。

在数据量小的时候使用插入排序,虽然插入排序的时间复杂度是O(n^2),但是它的常数项比较小,在数据量较小的时候具备较快的速度。

在数据量较大的时候,如果是基本类型,使用快速排序,如果是引用类型使用归并排序。这是因为快速排序是不稳定的,而插入排序和归并排序都是稳定性排序。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

java中如何对arrayList按数字大小逆序排序

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

java中如何对arrayList按数字大小逆序排序

这篇文章主要介绍了java中如何对arrayList按数字大小逆序排序问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-15

java中怎么对arrayList按数字大小逆序排序

这篇文章主要介绍“java中怎么对arrayList按数字大小逆序排序”,在日常操作中,相信很多人在java中怎么对arrayList按数字大小逆序排序问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java中
2023-07-06

Java如何对数组按照键名逆向排序

本文详细介绍了在Java中对数组按照键名逆向排序的方法,提供了三种方案:使用TreeMap、使用Arrays.sort()以及使用第三方库。具体步骤包括创建TreeMap或自定义Comparator,然后使用排序方法进行排序。示例代码展示了每种方案的实现和输出,帮助理解如何实现数组的键名逆向排序。
Java如何对数组按照键名逆向排序
2024-04-02

Java如何对数组逆向排序

本文详细介绍了在Java中对数组进行逆序排序的不同方法。这些方法包括使用Collections.reverseOrder()、Arrays.sort()和Comparator、StreamAPI以及循环。文章还提供了示例代码,演示了每种方法如何实现,并给出了有关选择最佳方法的建议。
Java如何对数组逆向排序
2024-04-02

PHP如何对数组按照键名逆向排序

本文介绍了如何使用PHP的ksort()函数对数组按键名进行逆向排序。ksort()函数可以按升序或降序对键名进行排序,并保持数组的索引关联。使用此函数时,只需传入需要排序的数组即可,可以根据需要指定排序顺序。本文提供了几种用法示例,并强调了ksort()函数的注意事项。通过阅读本文,开发者可以轻松掌握如何使用ksort()函数对PHP数组中的按键名进行逆向排序。
PHP如何对数组按照键名逆向排序
2024-04-02

python字典如何按值的大小排序

要按照字典的值进行排序,可以使用sorted()函数和lambda函数。首先,使用sorted()函数,指定key参数为一个lambda函数,该lambda函数接受一个字典的键值对作为参数,并返回该键值对的值。然后,将字典转换为键值对的列表
2023-10-12

java如何对arraylist中元素进行排序

这篇文章主要介绍了java如何对arraylist中元素进行排序,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。rrayList中的元素进行排序,主要考查的是对util包中的C
2023-05-30

如何使用PHP中的krsort()函数按键名对数组进行逆序排序

如何使用PHP中的krsort()函数按键名对数组进行逆序排序,需要具体代码示例PHP中的数组是一种非常有用的数据结构,它可以存储多个值,并根据键名进行访问和操作。在PHP中,我们可以使用krsort()函数对数组按照键名进行逆序排序。本文
如何使用PHP中的krsort()函数按键名对数组进行逆序排序
2023-11-18

Java如何对数组按照键名排序

本教程介绍了在Java中使用TreeMap对数组按照键名排序的方法,包括:创建TreeMap并添加数组元素遍历TreeMap以获取排序后的键名该方法易于理解和实现,时间复杂度为添加元素的O(logn)和遍历TreeMap的O(n)。此外,还列出了使用Arrays.sort()、自定义比较器和第三方库进行排序的其他方法。
Java如何对数组按照键名排序
2024-04-02

php如何把数组中几个值按大小排序

今天小编给大家分享一下php如何把数组中几个值按大小排序的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。php把数组中几个值按
2023-07-05

Java如何用“自然排序”算法对数组进行不区分大小写字母的排序

Java使用“自然排序”算法对字符串数组进行不区分大小写的排序。该算法通过定制比较器实现,将字符串转换为小写再比较。它可以按自然顺序对包含数字和大小写字母的字符串进行排序,且使用简单高效。局限性是仅适用于字符串,无法自定义排序顺序。替代方案是使用Guava库的Ordering.natural().nullsFirst()方法。此算法广泛应用于需要不区分大小写字母排序的场景。
Java如何用“自然排序”算法对数组进行不区分大小写字母的排序
2024-04-02

java如何将字符串从小到大排序

可以使用Java中的Arrays类的sort方法来实现字符串数组的排序,具体步骤如下:1. 创建一个字符串数组,存储待排序的字符串。2. 使用Arrays类的sort方法对字符串数组进行排序。3. 打印排序后的字符串数组。下面是一个示例代码
2023-09-26

python如何按照字典的值的大小进行排序

这篇文章主要介绍了python如何按照字典的值的大小进行排序,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。如何按照字典的值的大小进行排序我们知道,字典的本质是哈希表,本身是无
2023-06-27

PHP如何用“自然排序”算法对数组进行不区分大小写字母的排序

本篇文章介绍了使用PHP对数组执行不区分大小写字母的自然排序的方法。自然排序算法优先考虑数字顺序,而不是字母顺序。通过将数组元素转换为小写、使用usort()函数比较元素的自然排序版本,您可以按自然顺序对数组进行排序。示例代码展示了如何使用array_map()、usort()和natural_sort()函数实现此功能。
PHP如何用“自然排序”算法对数组进行不区分大小写字母的排序
2024-04-02

python如何输入三个数字从小到大排序

小编给大家分享一下python如何输入三个数字从小到大排序,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、说明 使用list.sort()的方法排列,首先要保证用户输入的数字必须是整数,如果不是整数,则需要提示用户输入错
2023-06-15

Java如何对数组进行逆向排序并保持索引关系

本文介绍了在Java中对数组进行逆向排序并保持索引关系的方法。该方法涉及确定数组类型、创建辅助数组、使用排序算法、定义逆序比较器、逆向排序数组以及将排序后的元素复制回原始数组。对于原始类型数组,使用Arrays.sort(),对于对象数组,使用Collections.sort()。使用自定义比较器可以定制排序行为。该方法适用于任何类型数组,时间复杂度为O(nlogn)。
Java如何对数组进行逆向排序并保持索引关系
2024-04-02

python如何实现按照键或者数值对字典进行排序

这篇文章主要介绍python如何实现按照键或者数值对字典进行排序,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!如何实现按照键或者数值对字典进行排序# 按照键或者数值对字典进行排序dict3 = {"low" : 3,
2023-06-27

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录