程序分析
如下图所示,所求对角线之和为蓝色填充的位置。
观察分析可得(横坐标用i
标识,竖坐标用j
标识),对角线的元素满足:i = j
或 i + j = 2
.即
if (i == j || (i + j) == 2){
sum += arr[i][j];
}
代码实现
package bennett.yangjun;
/*29、求一个3*3矩阵对角线元素之和*/
public class Test {
public static void main(String[] args) {
int[][] arr = {{1,2,3},{4,5,6},{7,8,9}};
System.out.println("3*3矩阵对角线元素之和为:"+sumDiagonal(arr));
}
//求对角线元素之和
private static int sumDiagonal(int[][] arr) {
int sum = 0;
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
if (i == j || (i + j) == 2){
sum += arr[i][j];
}
}
}
return sum;
}
}