矩阵区域和 --- 前缀和

目录

一:题目

二:算法原理

三:代码


一:题目

题目链接: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;
    }
};
相关推荐
xnglan9 分钟前
蓝桥杯手算题和杂题简易做法
数据结构·数据库·c++·python·算法·职场和发展·蓝桥杯
凛冬君主11 分钟前
插入排序专栏
java·算法·排序算法
melonbo19 分钟前
代理模式C++
c++·设计模式·系统安全·代理模式
stbomei36 分钟前
C 语言判断一个数是否是素数的三种方法文章提纲
c语言·开发语言·算法
小牛壮士38 分钟前
Tokenizer(切词器)的不同实现算法
开发语言·算法·c#
汤永红44 分钟前
week1-[顺序结构]大海
c++·算法·信睡奥赛
励志不掉头发的内向程序员1 小时前
类和对象(下)
开发语言·c++
博哥爱吃肉1 小时前
第2篇_Go语言基础语法_变量常量与数据类型
开发语言·算法·golang
二进制coder3 小时前
OpenBMC中C++策略模式架构、原理与应用
c++·架构·策略模式
Xの哲學4 小时前
TCP 连接管理:深入分析四次握手与三次挥手
网络·网络协议·算法