Leetcode矩阵

Leetcode.1572 矩阵对角线元素的和

解题思路:

使用一个row变量来记录层数,在循环中使用一个l变量记录左边到右边的值,使用一个r变量记录右边到左边的值,使用width变量记录矩阵的宽度

如图所示,可以通过改变row,l ,r来遍历两个对角线,当l和r相等时,那么就代表走到了两个对角线相交的位置,由于加了两便,所以直接减掉一次就好了,然后就可以完美得到结果

AC代码:

cpp 复制代码
class Solution {
public:
    int diagonalSum(vector<vector<int>>& mat) {
        int width=mat[0].size();
        int ans=0;
        int row=0;
        for(int l=0,r=width-1;l<width && r>=0;l++,r--){
            if(l==r) ans-=mat[row][l];
            ans+=mat[row][l];
            ans+=mat[row++][r];
        }
        return ans;
    }
};
相关推荐
wuweijianlove19 分钟前
算法设计中的空间复用与数据对齐优化的技术5
算法
yuan199971 小时前
基于 MATLAB PSO 工具箱的函数寻优算法
开发语言·算法·matlab
YUANQIANG20241 小时前
博弈论中势函数与势博弈构造:为什么看似 “先射箭后画靶”
算法·信息与通信
WBluuue1 小时前
Codeforces 1096 Div3(ABCDEFGH)
c++·算法
wanzehongsheng1 小时前
基于天文算法的双轴太阳能追踪系统:从原理到工程实现
算法
basketball6161 小时前
Kadane算法 C++实现
java·c++·算法
handler011 小时前
【C++】二叉搜索树详解及其模拟实现(代码)
开发语言·c++·算法·c··二叉搜索树·搜索树
luj_17681 小时前
残熵算法的稳健防灾逻辑
c语言·开发语言·c++·经验分享·算法
玖釉-1 小时前
二叉树基础详解:TreeNode、buildTree、deleteTree 与 printTree 的实现原理(C++)
c++·windows·算法
Severus_black1 小时前
【初阶数据结构与算法】八大排序之非比较排序(计数排序),一次性讲清!
数据结构·算法·排序算法