《从C/C++到Java入门指南》- 15. Arrays.sort() JDK接口的使用
Arrays.sort() JDK接口的使用
上节学习了 Array.sort()
这个接口,但是我个人不满足于简单的正向排序,我需要一个自定义的排序,怎么弄呢?
自定义范围
需要自定义数组范围可以在第二和第三个参数中传入索引,需要注意的是第二个索引是开区间。
import java.util.Arrays;
public class Main {public static void main(String[] args) {int[] ns = new int[] {5, 4, 3, 2, 1};Arrays.sort(ns, 2, ns.length); // ns.length 不参与排序System.out.println(Arrays.toString(ns));}
}
自定义规则
我们也可以和C++一样,自定义比较器。
import java.util.*;
public class Main {public static void main(String[] args) {Integer[] ns = new Integer[] {2, 87, 24, 45, 23, 13, 14, 156, 89};Arrays.sort(ns, new Comparator<Integer>() {public int compare(Integer a, Integer b) {return b - a;}});System.out.println(Arrays.toString(ns));}
}
这里用到的重构方法还是很熟悉的,但是这里的Integer
有点意思,其实是一个将int
包装后的类。
也可以使用一种更简单的方法:
import java.util.*;
public class Main {public static void main(String[] args) {Integer[] ns = new Integer[] {2, 87, 24, 45, 23, 13, 14, 156, 89};Arrays.sort(ns, (a, b) -> {return b - a;// b - a 大于零的放在前面});System.out.println(Arrays.toString(ns));}
}
当然还有一种方法,但是不过多讨论了,这里直接复制粘贴过来。
import java.util.*;public class Main {public static void main(String[] args){Integer[] arr = {5,4,7,9,2,12,54,21,1};//降序//重新实现Comparator接口Arrays.sort(arr, new compa());System.out.println(Arrays.toString(arr));}
}class compa implements Comparator<Integer>{@Overridepublic int compare(Integer o1, Integer o2) {// A.compareTo(B) A>B 返回1,A=B 返回0,A<B 返回-1// compareTo()返回值>0就交换// 如果02 > o1 就交换 =>降序return o2.compareTo(o1);}
}