对二维数组从两个维度进行排序(Arrays.sort()方法使用Lambada表达式)
平时经常遇到的是对一维数组进行排序,直接调用Arrays.sort()
方法,传入数组就可以实现。那么如何对二维数组进行排序呢?
这里对二维数组进行排序的意思是什么呢?
比如这样一个例子:
一个二维数组 int[][] arr ,第一维表示身高,第二维表示体重。现要求对这个二维数组进行排序。排序要求是优先按照身高从大到小排,当身高相同时,按照体重从小到大排。
实现:通过Arrays.sort()
方法,传入参数,利用Lambada表达式进行判断。
测试代码如下:
public static void main(String[] args) {
// 定义数组
int[][] arr = new int[][]{{7,0}, {4,4}, {7,1}, {5,0}, {6,1}, {5,2}};
// 利用Lambda表达式对数组排序
Arrays.sort(arr, (o1, o2) -> {
if (o1[0] == o2[0]) { //第一维的身高相同时
return Integer.compare(o1[1], o2[1]); // 从小到大
}
return Integer.compare(o2[0], o1[0]); // 从大到小
});
// 打印输出
for (int[] i :arr) {
String s = Arrays.toString(i);
System.out.println(s);
}
}
上面的测试代码中使用了 Integer.compare()
对两个数大小进行判断。如果用
return o1[1] - o2[1];
做减法也是可以的,但是在数据比较大的情况下(大于2147483647),会造成整型溢出而报错。所以推荐使用 Integer.compare()
判断。
输出结果:
[7, 0]
[7, 1]
[6, 1]
[5, 0]
[5, 2]
[4, 4]
可以看到,数组是先按照第二个维度排序的,当第二个维度的元素相等时,则按照第一个维度的元素进行排序。
什么是Lamdaba表达式?
可以将Lambda表达式理解为一个匿名函数; Lambda表达式允许将一个函数作为另外一个函数的参数; 我们可以把 Lambda 表达式理解为是一段可以传递的代码(将代码作为实参),也可以理解为函数式编程,将一个函数作为参数进行传递。
它支持将代码块作为方法参数、允许使用更简洁的代码来创建只有一个抽象方法的接口的实例。
Lambda 表达式的主要作用就是可以用于简化创建匿名内部类对象,Lambda 表达式的代码块将会用于实现抽象方法的方法体,Lambda 表达式就相当于一个匿名方法。
Lambda表达式的语法:
([Lambda参数列表,即形参列表]) -> {Lambda体,即方法体}
- 形参列表:形参列表允许省略类型,如果形参列表中只有一个参数,形参列表的圆括号也可以省略;
- 箭头(
->
):通过英文画线和大于符号组成; - 代码块:如果代码块只有一条语句,花括号可以省略。Lambda 代码块只有一条 return 语句,可以省略 return 关键字,Lambda 表达式会自动返回这条语句的值作为返回值。
拷贝小括号,写死右箭头,落地大括号,大括号中写上业务逻辑
特点:使用 "->"将参数和实现逻辑分离;( ) 中的部分是需要传入Lambda体中的参数;{ } 中部分,接收来自 ( ) 中的参数,完成一定的功能。