例:
封装一类 MatrixLocation,查询二维数组中的最大值及其位置。最大值用 double 类型的maxValue 存储,位置用 int 类型的 row 和 column 存储。封装执行主类,给定二维数组,输出最大值及其位置。封装执行主类。
这道题目就是一道简单的二维数组查找问题,遍历二维数组即可找到最大值。 代码实现(Java)
public class Main{
public static void main()(String[] args){
double[][] array={{3,16,9,12,29},{23,18,39,58,36},{27,35,56,48,6}}; //静态初始化一个doble型的二维数组
MatrixLocation.maxvalue(array); //调用maxvalue方法,输出二维数组中的最大值及其坐标(下标从0开始)
}
}
public class MatrixLocation {
public static void maxvalue(double[][] a){ //maxvalue是类方法
double maxValue=a[0][0]; //先将a[0][0]赋值给maxValue
int row=0,column=0;
for(int i=0;i<a.length;i++){ //遍历、比较
for(int j=0;j<a[0].length;j++){
if(a[i][j]>maxValue){
maxValue=a[i][j];
row=i;
column=j;
}
}
}
System.out.println("该二维数组中的最大值是"+maxValue);
System.out.println("最大值的在数组中的下标是:"+row+" "+column);
}
}
上述MatrixLocation类中matrix方法不能其实有一些问题,它只能输出最大值在数组中第一次出现的位置,这是由于题目已经规定好了最大值的下标用int row、int column表示。如果自己写的话,可以用另外的两个数组分别保存最大值的行下标与列下标,实现将最大值在数组中所有出现的位置都输出。