java中利用比较器实现Integer数组逆向排序以及可能出现的问题

本文探讨了在Java中如何利用Comparator实现Integer数组的逆向排序,指出默认正向排序的问题,并提供了逆向排序的实现代码。同时,文章详细解释了在数据由外界输入时,如果数组大小定义不当可能会导致的`NullPointerException`和`ArrayIndexOutOfBoundsException`异常,并提出了一种解决方案,即先定义并初始化足够大的数组,然后将输入数据赋值到另一数组并进行排序,以避免异常的发生。
摘要由CSDN通过智能技术生成

java中利用比较器实现Integer数组逆向排序以及可能出现的问题

在运用Arrays.sort()方法进行排序时,默认是正向排序。但是通常我们需要逆向排序,此时需要借助比较器Comparator。
在比较器中我们定义比较方式如下:

//定义MyComparator类实现Comparator接口,
//Comparator中泛型不再使用基本数据类型int,而应该使用Integer
class MyComparator implements Comparator<Interger>{
   
	@Override
	public int compare(Integer o1, Integer o2) {
   
		if(o1<o2) {
   
			return 1;
		}else if(o1>o2) {
   
			return -1;
		}else {
    
			return 0;
		}
	}
}

再借助Arrays.sort(Integer[] a, Comparator<? super Integer> c)方法就可以实现数组的逆向排序,但是此处数组必须为Integer类型数组。
下面是测试排序的代码:

//定义Test类实现Integer数组逆向排序
public class Test {
   
	public static void main(String[] args) {
   
		Integer[] a={
   
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值