在 Java 中对列表进行排序

您所在的位置:网站首页 java有序列表 在 Java 中对列表进行排序

在 Java 中对列表进行排序

2023-10-01 13:16| 来源: 网络整理| 查看: 265

在 Java 中使用 Collections.sort() 方法对列表进行排序 在 Java 中使用 Collections.reverseorder() 方法对列表进行排序 在 Java 中使用 Stream.sorted() 方法对列表进行排序 在 Java 中使用 Comparator.naturalOrder() 方法对 ArrayList 进行排序 在 Java 中对列表进行排序

列表是一个有序集合,可以以任何顺序存储项目。我们可以将传统算法应用于列表。

Ezoic

本教程将演示如何使用不同的函数在 Java 中对列表进行排序。

Ezoic 在 Java 中使用 Collections.sort() 方法对列表进行排序

我们可以使用 Collection 类中的 sort() 函数对列表进行排序。我们可以使用列表对象,它会修改元素的顺序。它按升序对列表进行排序。

例如,

import java.util.*; import java.util.stream.*; public class Main { public static void main(String[] args) { List slist = Arrays.asList(4,5,1,2,8,9,6); Collections.sort(slist); System.out.println("After Sorting: "+ slist); } } Ezoic

输出:

After Sorting: [1, 2, 4, 5, 6, 8, 9]

我们可以看到,在上面的代码中,原始列表被修改并按适当的顺序排序。

注意列表中应该有相同类型的元素;否则,它将抛出 CLassCastException。

在 Java 中使用 Collections.reverseorder() 方法对列表进行排序

我们使用 Collections.reverseorder() 方法按降序对 ArrayList 进行排序。我们不直接使用这种方法。首先使用 Collections.sort() 方法进行升序排序,然后使用 Collections.reverseorder() 方法进行降序排序。

请参考下面的代码。

Ezoic import java.util.*; import java.util.stream.*; public class Main { public static void main(String[] args) { List slist = Arrays.asList(4,5,1,2,8,9,6); Collections.sort(slist, Collections.reverseOrder()); System.out.println("After Sorting: "+ slist);} }

输出:

After Sorting: [9, 8, 6, 5, 4, 2, 1]

我们在上面的代码中创建了一个列表,然后使用 Collections.sort() 方法对其进行排序。然后使用 Collections.reverseorder() 方法按降序对其进行排序。

在 Java 中使用 Stream.sorted() 方法对列表进行排序

sorted() 函数在 java.util 包 中的 Stream 接口中定义。通过使用此方法,列表按升序排序。如果列表中的元素不是同一类型,则抛出 java.lang.ClassCastEcxeption。

在这里,我们将使用 stream() 函数来管理列表中元素的集合,collect() 将接收和存储元素,而 tolist() 函数将返回已排序的最终列表命令。

例如,

import java.util.*; import java.util.stream.*; public class Main { public static void main(String[] args) { List slist = Arrays.asList(4,5,1,2,8,9,6); List sortedList = slist.stream().sorted().collect(Collectors.toList()); System.out.println("After Sorting: "+ sortedList); } }

输出:

After Sorting: [1, 2, 4, 5, 6, 8, 9]

请注意,在上面的示例中创建了一个新列表。

在 Java 中使用 Comparator.naturalOrder() 方法对 ArrayList 进行排序

Java 中的 Comparator 接口可以根据所需的数据成员对用户创建的类的对象进行排序。我们也可以使用它对列表进行排序。

naturalOrder() 函数将按升序对元素进行排序。

请参考下面给出的代码。

import java.util.*; import java.util.stream.*; public class Main { public static void main(String[] args) { List slist = Arrays.asList(4,5,1,2,8,9,6); slist.sort(Comparator.naturalOrder()); System.out.println("After Sorting: "+ slist); } }

输出:

After Sorting: [1, 2, 4, 5, 6, 8, 9] Ezoic

使用此方法将空元素排在顶部。对于字母表,首先对以大写字母开头的单词进行排序,然后以小写字母开头的单词按升序排序。

我们可以使用前面讨论的 reverseOrder() 函数按降序排序。

例如,

import java.util.*; import java.util.stream.*; public class Main { public static void main(String[] args) { List slist = Arrays.asList(4,5,1,2,8,9,6); slist.sort(Comparator.reverseOrder()); System.out.println("After Sorting: "+ slist); } }

输出:

After Sorting: [9, 8, 6, 5, 4, 2, 1]


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3