一、题目
利用随机函数产生16个1~10的随机整数给一个4*4的二维数组。
(1)二维数组按行列输出;
(2)求最外一圈元素之和;
(3)求主对角线中最大元素的值及其位置。
二、实验代码
问题解释详见代码注释。
package fighting;
public class fighting
{
public static void main(String[] args)
{
int sum=0,row=0,col=0;
int a[][]=new int[4][4];
int max=a[0][0];
for(int i=0;i<a.length;i++)
{
for(int j=0;j<a[i].length;j++)
{
//a[i][j]=r.nextInt();//产生随机整数,需要在前面加上Random r=new Random()和导入Random类:import java.util.Random;
a[i][j]=(int)(Math.random()*10+1);//产生1~10的随机整数,(int)表示将double类型强转成整型
System.out.print(a[i][j]+"\t");
if(i==j&&a[i][j]>max)//求矩阵主对角线最大的元素,主对角线元素的特点是行和列相等
{
max=a[i][j];
row=i;
col=j;
}
}
System.out.println();
}
//sum=a[0][0]+a[0][1]+a[0][2]+a[0][3]+a[1][0]+a[1][3]+a[2][0]+a[2][3]+a[3][0]+a[3][1]+a[3][2]+a[3][3];//对于本题求矩阵最外一圈元素之和的粗暴求法
for(int i=0;i<a.length;i++)//该循环主要计算第一行和最后一行元素的的值
{
sum+=a[0][i];
sum+=a[a.length-1][i];
}
for(int j=1;j<a.length-1;j++)//该循环主要计算中间n-2行的头尾元素的值
{
sum+=a[j][0];
sum+=a[j][a.length-1];
}//求矩阵最外一圈元素之和的普遍方法
System.out.println("最外一圈元素之和为:"+sum);
System.out.println("主对角线中最大元素a["+row+"]["+col+"]值为:"+max);
}
}
三、运行结果