在 Java 中对列表进行排序
-
在 Java 中使用
Collections.sort()
方法对列表进行排序 -
在 Java 中使用
Collections.reverseorder()
方法对列表进行排序 -
在 Java 中使用
Stream.sorted()
方法对列表进行排序 -
在 Java 中使用
Comparator.naturalOrder()
方法对 ArrayList 进行排序
列表是一个有序集合,可以以任何顺序存储项目。我们可以将传统算法应用于列表。
本教程将演示如何使用不同的函数在 Java 中对列表进行排序。
在 Java 中使用 Collections.sort()
方法对列表进行排序
我们可以使用 Collection
类中的 sort()
函数对列表进行排序。我们可以使用列表对象,它会修改元素的顺序。它按升序对列表进行排序。
例如,
import java.util.*;
import java.util.stream.*;
public class Main
{
public static void main(String[] args)
{
List<Integer> slist = Arrays.asList(4,5,1,2,8,9,6);
Collections.sort(slist);
System.out.println("After Sorting: "+ slist);
}
}
输出:
After Sorting: [1, 2, 4, 5, 6, 8, 9]
我们可以看到,在上面的代码中,原始列表被修改并按适当的顺序排序。
注意列表中应该有相同类型的元素;否则,它将抛出 CLassCastException
。
在 Java 中使用 Collections.reverseorder()
方法对列表进行排序
我们使用 Collections.reverseorder()
方法按降序对 ArrayList 进行排序。我们不直接使用这种方法。首先使用 Collections.sort()
方法进行升序排序,然后使用 Collections.reverseorder()
方法进行降序排序。
请参考下面的代码。
import java.util.*;
import java.util.stream.*;
public class Main
{
public static void main(String[] args)
{
List<Integer> 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<Integer> slist = Arrays.asList(4,5,1,2,8,9,6);
List<Integer> 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<Integer> 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]
使用此方法将空元素排在顶部。对于字母表,首先对以大写字母开头的单词进行排序,然后以小写字母开头的单词按升序排序。
我们可以使用前面讨论的 reverseOrder()
函数按降序排序。
例如,
import java.util.*;
import java.util.stream.*;
public class Main
{
public static void main(String[] args)
{
List<Integer> 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]