前缀和-1314.矩阵区域和-力扣(LeetCode)

一、题目解析

1、返回的answer矩阵和mat矩阵大小一致

2、answer[i][j]的值为以(i,j)位置向外扩展k位置的矩形位置所有元素的和

二、算法原理

解法:二维前缀和

dp表计算公式

应用公式

下标映射关系

所需的x1、y1、x2和y2的计算

细节问题:

1、dp表和mat的下标映射关系
2、answer表和dp表的下标映射关系

三、代码示例

cpp 复制代码
class Solution {
public:
    vector<vector<int>> matrixBlockSum(vector<vector<int>>& mat, int k)
    {
        int m = mat.size(),n = mat[0].size();
        vector<vector<int>> dp(m+1,vector<int>(n+1,0)),ret(m,vector<int>(n));
        for(int i = 1;i<m+1;i++)
        {
            for(int j = 1;j<n+1;j++)
                dp[i][j] = dp[i-1][j]+dp[i][j-1]-dp[i-1][j-1]+mat[i-1][j-1];
        }
        int x1,x2,y1,y2;
        for(int i = 0;i<m;i++)
        {
            for(int j = 0;j<n;j++)
            {
                x1 = max(0,i-k),y1 = max(0,j-k);
                x2 = min(m-1,i+k),y2 = min(n-1,j+k);
                ret[i][j] = dp[x2+1][y2+1]-dp[x1][y2+1]-dp[x2+1][y1]+dp[x1][y1];
            }
        }
        return ret;
    }
};

看到最后,如果对您有所帮助,还请点赞、收藏和关注,我们下期再见!

相关推荐
weixin_3077791329 分钟前
ClickHouse Windows迁移方案与测试
linux·c++·数据仓库·windows·clickhouse
老猿讲编程40 分钟前
LCM中间件入门(1):工作原理核心概念及Ubuntu环境下的C++实践
c++·ubuntu·中间件·lcm
爱掉发的小李1 小时前
Linux 环境下 Docker 安装与简单使用指南
java·linux·运维·c++·python·docker·php
澄澈i2 小时前
设计模式学习[17]---组合模式
c++·学习·设计模式·组合模式
恣艺2 小时前
LeetCode 124:二叉树中的最大路径和
算法·leetcode·职场和发展
weisian1513 小时前
力扣经典算法篇-42-矩阵置零(辅助数组标记法,使用两个标记变量)
算法·leetcode·矩阵
恣艺3 小时前
LeetCode 123:买卖股票的最佳时机 III
算法·leetcode·职场和发展
jdlxx_dongfangxing3 小时前
2023 年 NOI 最后一题题解
c++·noi
Q741_1473 小时前
优选算法 力扣 202.快乐数 快慢双指针 解决带环问题 C++解题思路 每日一题
c++·算法·leetcode·快慢双指针·环形问题