每日一题——LeetCode1572.矩阵对角线元素的和

方法一 遍历矩阵

如果矩阵中某个位置(x,y)处于对角线上,那么这个位置必定满足:

x=y 或 x+y = len-1 (len为矩阵长度)

javascript 复制代码
var diagonalSum = function(mat) {
    let len = mat.length;
    let sum = 0;
    for (let i = 0; i < len; i++) {
        for (let j = 0; j < len; j++) {
            if (i == j || i + j == len - 1) {
                sum += mat[i][j];
            }
        }
    }
    return sum;
};

消耗时间和内存情况:

方法二 枚举对角线元素:

逐行遍历,记当前行号为i,每一行的对角线元素为(i,i)和(i,len-i-1)

如果len为奇数则对角线交点会被计算两次,需要减掉一次

用len&1,如果len为奇数结果为1,len为偶数结果为0

javascript 复制代码
var diagonalSum = function(mat) {
    let len = mat.length, mid = Math.floor(len / 2);
    let sum = 0;
    for (let i = 0; i < len; ++i) {
        sum += mat[i][i] + mat[i][len - 1 - i];
    }
    return sum - mat[mid][mid] * (len & 1);
};

消耗时间和内存情况:

相关推荐
秋氘渔5 分钟前
Vue 3 组合式API中的生命周期钩子函数介绍
前端·javascript·vue.js
悦悦子a啊6 分钟前
将学生管理系统改造为C/S模式 - 开发过程报告
java·开发语言·算法
拉不动的猪14 分钟前
requestAnimationFrame 与 JS 事件循环:宏任务执行顺序分析
前端·javascript·面试
han_14 分钟前
开发提效利器 - 用好Snippets
前端·javascript·visual studio code
痕忆丶15 分钟前
双线性插值缩放算法详解
算法
mCell34 分钟前
为什么在 Agent 时代,我选择了 Bun?
javascript·agent·bun
谎言西西里1 小时前
掌握原型链,写出不翻车的 JS 继承
javascript
_codemonster1 小时前
深度学习实战(基于pytroch)系列(四十八)AdaGrad优化算法
人工智能·深度学习·算法
鹿角片ljp2 小时前
力扣140.快慢指针法求解链表倒数第K个节点
算法·leetcode·链表
自由生长20242 小时前
位运算第1篇-异或运算-快速找出重复数字
算法