欢迎来IT培训班!

咨询热线 18940085928

IT培训网 > 知识学习 > JAVA开发 >

Java sort()数组排序(升序和降序)

授课机构:IT培训班

地址:北京

网报价格:详询

课程原价:

咨询热线:18940085928

课程详情 相关推荐 学校地址 网上报名

我们在学习 Java 的过程中肯定会遇到对数组进行升序或降序等排序问题,本节主要介绍如何实现 Java 数组的升序和降序。Java 语言使用 Arrays 类提供的 sort() 方法来对数组进行排序。

升序

使用 java.util.Arrays 类中的 sort() 方法对数组进行升序分为以下两步:
  1. 导入 java.util.Arrays 包。
  2. 使用 Arrays.sort(数组名) 语法对数组进行排序,排序规则是从小到大,即升序。

假设在数组 scores 中存放了 5 名学生的成绩,现在要实现从低到高排列的功能。在这里使用 Arrays.sort() 方法来实现,具体代码如下:

		
  1. public static void main(String[] args) {
  2. // 定义含有5个元素的数组
  3. double[] scores = new double[] { 78, 45, 85, 97, 87 };
  4. System.out.println("排序前数组内容如下:");
  5.  
  6. // 对scores数组进行循环遍历
  7. for (int i = 0; i < scores.length; i++) {
  8. System.out.print(scores[i] + "\t");
  9. }
  10. System.out.println("\n排序后的数组内容如下:");
  11.  
  12. // 对数组进行排序
  13. Arrays.sort(scores);
  14.  
  15. // 遍历排序后的数组
  16. for (int j = 0; j < scores.length; j++) {
  17. System.out.print(scores[j] + "\t");
  18. }
  19. }
如上述代码所示,要对一个数组进行升序排列,只需要调用 Arrays.sort() 方法即可。运行后的输出结果如下所示。
排序前数组内容如下:
78.0    45.0    85.0    97.0    87.0   
排序后的数组内容如下:
45.0    78.0    85.0    87.0    97.0

降序

在 Java 语言中使用 sort 实现降序有两种方法,简单了解即可。

1)利用 Collections.reverseOrder() 方法(Collections 是一个包装类。大家可以学习《Java Collections类》一节详细了解):

		
  1. public static void main(String[] args) {
  2. Integer[] a = { 9, 8, 7, 2, 3, 4, 1, 0, 6, 5 }; // 数组类型为Integer
  3. Arrays.sort(a, Collections.reverseOrder());
  4. for (int arr : a) {
  5. System.out.print(arr + " ");
  6. }
  7. }
输出结果如下:

9 8 7 6 5 4 3 2 1 0 

2)实现 Comparator 接口的复写 compare() 方法,代码如下:

		
  1. public class Test {
  2. public static void main(String[] args) {
  3. /*
  4. * 注意,要想改变默认的排列顺序,不能使用基本类型(int,double,char)而要使用它们对应的类
  5. */
  6. Integer[] a = { 9, 8, 7, 2, 3, 4, 1, 0, 6, 5 };
  7. // 定义一个自定义类MyComparator的对象
  8. Comparator cmp = new MyComparator();
  9. Arrays.sort(a, cmp);
  10. for (int arr : a) {
  11. System.out.print(arr + " ");
  12. }
  13. }
  14. }
  15.  
  16. // 实现Comparator接口
  17. class MyComparator implements Comparator<Integer> {
  18. @Override
  19. public int compare(Integer o1, Integer o2) {
  20. /*
  21. * 如果o1小于o2,我们就返回正值,如果o1大于o2我们就返回负值, 这样颠倒一下,就可以实现降序排序了,反之即可自定义升序排序了
  22. */
  23. return o2 - o1;
  24. }
  25. }
输出结果如下所示。

9 8 7 6 5 4 3 2 1 0 

注意:使用以上两种方法时,数组必须是包装类型,否则会编译不通过。 在 Java 中实现数组排序的方式很多,除了利用以上的几种方法外,还可以编写自定义方法来实现自己的排序算法,有兴趣的读者可以尝试编写。
  • 学校名称:IT培训网

    固定电话:18940085928

    授课地址:线下 预约名额

报名信息