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];

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

相关推荐
Shun_Tianyou14 分钟前
Python Day17 面向对象 及例题分析
开发语言·数据结构·python·算法
a cool fish(无名)31 分钟前
8.1-使用向量存储值列表
人工智能·python·算法
茴香豆的茴142 分钟前
转码刷 LeetCode 笔记[1]:3.无重复字符的最长子串(python)
笔记·算法·leetcode
美团技术团队43 分钟前
ACL 2025 | 美团技术团队论文精选
人工智能·算法
xnglan1 小时前
数据结构与算法:队列的表示和操作的实现
c语言·数据结构·算法·链表
快去睡觉~1 小时前
力扣46:全排列
算法·leetcode·动态规划
蒋星熠1 小时前
字母异位词分组(每天刷力扣hot100系列)
开发语言·c++·算法·leetcode·职场和发展
FirstFrost --sy1 小时前
数据结构之排序
c语言·数据结构·算法·排序算法
竹子_231 小时前
《零基础入门AI:传统机器学习核心算法(决策树、随机森林与线性回归)》
人工智能·算法·机器学习
Darkwanderor1 小时前
哈希相关的模拟实现
数据结构·c++·算法·哈希算法