迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

Java 中排序链表

作者:迹忆客 最近更新:2023/10/16 浏览次数:

Java 中的链表是一种数据结构或集合,允许用户在内存中创建动态数组。该列表不包含任何预定义的大小。它动态地创建节点并在单个内存地址中存储值和对下一个节点的引用。列表元素按顺序保留值,或者列表保持插入元素的插入顺序。

排序被定义为以一定顺序排列数据结构中的元素的方法。根据要求,排列可以是升序或降序。请注意,可以有多种方法来对列表集合进行排序。

下面是对数组中的元素进行排序的代码块。

import java.text.Collator;
import java.util.Comparator;
import java.util.LinkedList;

public class Main {
    public static void main(String[] args) {
        LinkedList<String> list = new LinkedList<String>();
        list.add("ab");
        list.add("bb");
        list.add("aA");
        list.add("bB");
        System.out.println(list);
        list.sort(new Comparator<String>() {
            @Override
            public int compare(String s1, String s2) {
                return Collator.getInstance().compare(s1, s2);
            }
        });
        System.out.println(list);
    }
}

在上面的代码块中,使用 new 关键字实例化了一个列表。关键字实例化 String 数据类型的链表并在内部调用构造函数。然后,列表实例调用 add 方法来填充列表中的元素。该值被打印以检查插入顺序。

sort 方法存在于 List 接口中。该函数根据作为参数给出的一些比较器对列表进行排序。比较器用于比较传递的元素列表。

你应该考虑的一点是对传递的值进行排序并确保它们必须属于同一类型。如果值的类型不同或元素不可比较,则该类将抛出 ClassCastException

排序的内部实现是使用 merge sort 命令完成的,该命令足够有效并且在 log n 时间内进行比较。所以形成了一个 new Comparator 实例,它覆盖了 compare 方法。实现是方法覆盖和提供实现的传统方式。

相反,可以使用使用 Java 8 lambda 函数的单行实现。该接口是一个函数式接口,只有一个方法可以调用。lambda 直接获取接口中存在的参数数量。上面代码的单行 Java 8 表示如下所示。

list.sort((o1, o2) -> Collator.getInstance().compare(o1, o2));

比较列表中元素的实际语句是 collator 类。这个类本质上是抽象的,定义了方法的原型。实现存在于扩展它们的抽象类中。

collator 类比较区域设置敏感的字符串。getInstance 方法获取具有当前默认 Locale 值的实例。compare 函数比较基于 collator 的值,并根据大于、小于或等于的值返回 +1-10

上面代码的输出如下所示。第二行表示排列形式的输出。根据键盘上字符的 ASCII 序列,大写字母的范围(A-Z)高于小字母(a-z)。因此,第二行中的结果列表首先打印小写 bb,然后打印 bB,因为它有大写字母。

[ab, bb, aA, bB]
[aA, ab, bb, bB]

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

如何在 Java 中延迟几秒钟的时间

发布时间:2023/12/17 浏览次数:217 分类:Java

本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。

如何在 Java 中把 Hashmap 转换为 JSON 对象

发布时间:2023/12/17 浏览次数:187 分类:Java

它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。

如何在 Java 中按值排序 Map

发布时间:2023/12/17 浏览次数:171 分类:Java

本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map 进行排序,并列出了一些示例代码来理解它。

如何在 Java 中打印 HashMap

发布时间:2023/12/17 浏览次数:192 分类:Java

本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。

在 Java 中更新 Hashmap 的值

发布时间:2023/12/17 浏览次数:146 分类:Java

本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。

Java 中的 hashmap 和 map 之间的区别

发布时间:2023/12/17 浏览次数:79 分类:Java

本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,

在 Java 中获取用户主目录

发布时间:2023/12/17 浏览次数:218 分类:Java

这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。

Java 中 size 和 length 的区别

发布时间:2023/12/17 浏览次数:179 分类:Java

这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。

Java 中的互斥锁

发布时间:2023/12/17 浏览次数:111 分类:Java

了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便