矩阵区域和 --- 前缀和

目录

一:题目

二:算法原理

三:代码


一:题目

题目链接:1314. 矩阵区域和 - 力扣(LeetCode)

二:算法原理

三:代码

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>> ret(m,vector<int>(n));
        vector<vector<int>> dp(m+1,vector<int>(n+1));

        //预处理前缀和
        for(int i = 1; i <= m;i++)
        {
            for(int j = 1; j <= n; j++)
            {
                dp[i][j] = dp[i-1][j] + dp[i][j-1]-dp[i-1][j-1]+mat[i-1][j-1];
            }
        } 

        //使用前缀和
        for(int i = 0; i < m ;i++)
        {
            for(int j = 0; j < n ; j++)
            {
                int x1 = max(0,i-k)+1;
                int y1 = max(0,j-k)+1;
                int x2 = min(m-1,i+k)+1;
                int y2 = min(n-1,j+k)+1;

                ret[i][j] = dp[x2][y2] - dp[x1-1][y2]-dp[x2][y1-1]+dp[x1-1][y1-1];
            }
        }
        
        return ret;
    }
};
相关推荐
ShineSpark10 分钟前
C++面试3——const关键字的核心概念、典型场景和易错陷阱
c++·算法·面试
爱吃涮毛肚的肥肥(暂时吃不了版)3 小时前
仿腾讯会议——音频服务器部分
c++·qt·面试·职场和发展·音视频·腾讯会议
智驱力人工智能3 小时前
AI移动监测:仓储环境安全的“全天候守护者”
人工智能·算法·安全·边缘计算·行为识别·移动监测·动物检测
DpHard3 小时前
自用Vscode 配置c++ debug环境
c++·ide·vscode
hy____1234 小时前
C++多态的详细讲解
开发语言·c++
superior tigre4 小时前
C++学习:六个月从基础到就业——C++20:范围(Ranges)进阶
c++·学习·c++20
小葡萄20254 小时前
黑马程序员C++2024版笔记 第0章 C++入门
开发语言·c++·笔记
代码小将4 小时前
力扣992做题笔记
算法·leetcode
编程绿豆侠5 小时前
力扣HOT100之二叉树:199. 二叉树的右视图
算法·leetcode·职场和发展
不二一5 小时前
linux c++头文件生成源文件 使用python脚本 配置vim快捷键
linux·c++·python