在 Java 中对列表进行排序

Lovey Arora 2023年1月30日 2021年10月2日
  1. 在 Java 中使用 Collections.sort() 方法对列表进行排序
  2. 在 Java 中使用 Collections.reverseorder() 方法对列表进行排序
  3. 在 Java 中使用 Stream.sorted() 方法对列表进行排序
  4. 在 Java 中使用 Comparator.naturalOrder() 方法对 ArrayList 进行排序
在 Java 中对列表进行排序

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

本教程将演示如何使用不同的函数在 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]

相关文章 - Java List