java通过Arrays.sort(int[] a)实现由大到小排序的方法实现
作者:听海边涛声
一、方法重载
Arrays.sort()方法有许多重载版本,可以接受不同类型的输入,并对它们进行排序。以下是一些常见的重载版本:
Arrays.sort(byte[] a): 对字节型数组进行排序Arrays.sort(char[] a): 对字符型数组进行排序Arrays.sort(double[] a): 对双精度浮点型数组进行排序Arrays.sort(float[] a): 对浮点型数组进行排序Arrays.sort(int[] a): 对整型数组进行排序Arrays.sort(long[] a): 对长整型数组进行排序Arrays.sort(short[] a): 对短整型数组进行排序Arrays.sort(Object[] a): 对对象数组进行排序,此方法要求数组中的对象必须实现了Comparable接口Arrays.sort(T[] a, Comparator<? super T> c): 对对象数组进行排序,使用一个定制的Comparator对象来比较数组中的元素
二、注意事项
对于对象数组,如果使用默认的
Arrays.sort(Object[] a)方法进行排序,那么数组中的对象必须实现了Comparable接口。如果对象没有实现这个接口,那么在运行时会抛出ClassCastException。Arrays.sort(T[] a, Comparator<? super T> c)这个版本的方法允许你传入一个Comparator对象来自定义排序的规则。如果传入的Comparator对象为null,那么此方法将会使用元素的自然顺序进行排序。对于对象数组的排序,
Arrays.sort()方法使用的是稳定的排序算法,这意味着等值的元素在排序后会保持他们原有的相对位置。Arrays.sort()方法的时间复杂性为O(n log n)。Arrays.sort()方法会对输入的数组进行直接排序,也就是说,它会改变输入数组的元素顺序。如果不希望改变原数组的元素顺序,那么在排序前需要先对数组进行复制。
三、举例
java的Arrays.sort(int[] a)实现的是由小到大的排序,那么如果要实现由大到小排序怎么办呢?一种方法是用下面的步骤:
1)先通过Arrays.sort(int[] a)对数组a实现由小到大排序;
2)然后创建另外一个同长度的数组b,将数组a的元素从后面往前拷贝到b数组中;
3)通过System.arraycopy将数组b的内容拷贝到数组a中。
import java.util.Arrays;
public class Test {
public static void main(String[] args) {
int[] a = {1, 3, 2, 4};
int[] b = new int[a.length];
Arrays.sort(a); // 将数组a的内容由小到大排序
// 将数组a的内容从后到前拷贝到数组b中
for (int i = 0; i < a.length; i ++) {
b[a.length -1 - i] = a[i];
}
System.arraycopy(b, 0, a, 0, a.length); // 将数组b的内容拷贝到数组a中
System.out.println("content in array a:");
for (int i = 0; i < a.length; i++) {
System.out.print(a[i] + ",");
}
System.out.println();
}
}
输出内容:

到此这篇关于java中的Arrays.sort()排序方法实现的文章就介绍到这了,更多相关java Arrays.sort排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
