在 Java 中对列表进行排序

Lovey Arora 2023年10月12日
  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