《从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>{
@Override
public 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);
}
}
原文地址:https://blog.csdn.net/2301_79640368/article/details/140545078
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!