1572. 矩阵对角线元素的和

给你一个正方形矩阵 mat,请你返回矩阵对角线元素的和。

请你返回在矩阵主对角线上的元素和副对角线上且不在主对角线上元素的和。

示例 1:

复制代码
输入:mat = [[1,2,3],
            [4,5,6],
            [7,8,9]]
输出:25
解释:对角线的和为:1 + 5 + 9 + 3 + 7 = 25
请注意,元素 mat[1][1] = 5 只会被计算一次。

示例 2:

复制代码
输入:mat = [[1,1,1,1],
            [1,1,1,1],
            [1,1,1,1],
            [1,1,1,1]]
输出:8

示例 3:

复制代码
输入:mat = [[5]]
输出:5

提示:

  • n == mat.length == mat[i].length
  • 1 <= n <= 100
  • 1 <= mat[i][j] <= 100
java 复制代码
class Solution {
    public int diagonalSum(int[][] mat) {
        int totalSum=0;
        int size=mat.length;
        for(int i=0;i<size;++i){
            int reverseIndex=size-i-1;
            totalSum +=mat[i][i];
            if (i!=reverseIndex){
                totalSum+=mat[i][reverseIndex];
            }
        }

        return totalSum;
    }
}

因为是方正所以size=mat.length;

主对角线:mat[i][i];

副对角线:mat[i][size-i-1];

如果是偶数列(行)则不会有重复,如果是奇数列,则但行标=列标时,中间元素会重复,不能加。

相关推荐
Xの哲學16 小时前
Linux SMP 实现机制深度剖析
linux·服务器·网络·算法·边缘计算
wuk99817 小时前
使用PCA算法进行故障诊断的MATLAB仿真
算法·matlab
额呃呃17 小时前
二分查找细节理解
数据结构·算法
无尽的罚坐人生17 小时前
hot 100 283. 移动零
数据结构·算法·双指针
永远都不秃头的程序员(互关)17 小时前
C++动态数组实战:从手写到vector优化
c++·算法
水力魔方18 小时前
武理排水管网模拟分析系统应用专题5:模型克隆与并行计算
数据库·c++·算法·swmm
谈笑也风生19 小时前
经典算法题型之排序算法(三)
java·算法·排序算法
大佬,救命!!!20 小时前
对算子shape相关的属性值自动化处理
python·算法·自动化·学习笔记·算子·用例脚本·算子形状
高山上有一只小老虎20 小时前
小红的推荐系统
java·算法
冰西瓜60020 小时前
贪心(一)——从动态规划到贪心 算法设计与分析 国科大
算法·贪心算法·动态规划