矩阵区域和 --- 前缀和

目录

一:题目

二:算法原理

三:代码


一:题目

题目链接: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;
    }
};
相关推荐
不辣的皮蛋君21 小时前
2026年短视频矩阵系统实战:如何用工具实现多平台一键分发,效率提升300%
人工智能·线性代数·矩阵
.千余21 小时前
【C++】手写双向链表:list容器模拟实现
开发语言·c++·笔记·学习·其他
QuZero21 小时前
Guava Cache Deep Dive
java·后端·算法·guava
随意起个昵称21 小时前
线性dp-LIS题目4(A Twisty Movement)
算法·动态规划
liulilittle21 小时前
过冲:拥塞控制的呼吸与盲行
linux·网络·c++·tcp/ip·计算机网络·tcp·通信
Felven21 小时前
B. Fair Numbers
数据结构·算法
人道领域21 小时前
【LeetCode刷题日记】93.复原IP地址
java·开发语言·算法·leetcode
jarreyer1 天前
【算法记录1】模型训练问题
算法
Felven1 天前
D. Friends and the Restaurant
算法
想吃火锅10051 天前
【leetcode】165.比较版本号js
javascript·算法·leetcode