我们在学习 Java 的过程中肯定会遇到对数组进行升序或降序等排序问题,本节主要介绍如何实现 Java 数组的升序和降序。Java 语言使用 Arrays 类提供的 sort() 方法来对数组进行排序。
升序
使用 java.util.Arrays 类中的 sort() 方法对数组进行升序分为以下两步:
假设在数组 scores 中存放了 5 名学生的成绩,现在要实现从低到高排列的功能。在这里使用 Arrays.sort() 方法来实现,具体代码如下:
如上述代码所示,要对一个数组进行升序排列,只需要调用 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类》一节详细了解):
输出结果如下:
9 8 7 6 5 4 3 2 1 0
2)实现 Comparator 接口的复写 compare() 方法,代码如下:
输出结果如下所示。
9 8 7 6 5 4 3 2 1 0
注意:使用以上两种方法时,数组必须是包装类型,否则会编译不通过。
在 Java 中实现数组排序的方式很多,除了利用以上的几种方法外,还可以编写自定义方法来实现自己的排序算法,有兴趣的读者可以尝试编写。
Java排序方法sort的使用详解
对数组的排序:
//对数组排序public void arraySort(){ int[] arr = {1,4,6,333,8,2}; Arrays.sort(arr);//使用java.util.Arrays对象的sort方法 for(int i=0;i<arr.length;i++){ System.out.println(arr[i]); }}对集合的排序:
//对list升序排序 public void listSort1(){ List<Integer> list = new ArrayList<Integer>(); list.add(1); list.add(55); list.add(9); list.add(0); list.add(2); Collections.sort(list);//使用Collections的sort方法 for(int a :list){ System.out.println(a); } } //对list降序排序 public void listSort2(){ List<Integer> list = new ArrayList<Integer>(); list.add(1); list.add(55); list.add(9); list.add(0); list.add(2); Collections.sort(list, new Comparator<Integer>() { public int compare(Integer o1, Integer o2) { return o2 - o1; } });//使用Collections的sort方法,并且重写compare方法 for(int a :list){ System.out.println(a); } }到此这篇关于详解Java sort()数组排序(升序和降序)的文章就介绍到这了,更多相关Java sort()数组排序内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!