(力扣)1314.矩阵区域和

给你一个 m x n 的矩阵 mat 和一个整数 k ,请你返回一个矩阵 answer ,其中每个 answer[i][j] 是所有满足下述条件的元素 mat[r][c] 的和:

  • i - k <= r <= i + k,
  • j - k <= c <= j + k
  • (r, c) 在矩阵内。

示例 1:

复制代码
输入:mat = [[1,2,3],[4,5,6],[7,8,9]], k = 1
输出:[[12,21,16],[27,45,33],[24,39,28]]

示例 2:

复制代码
输入:mat = [[1,2,3],[4,5,6],[7,8,9]], k = 2
输出:[[45,45,45],[45,45,45],[45,45,45]]

提示:

  • m == mat.length
  • n == mat[i].length
  • 1 <= m, n, k <= 100
  • 1 <= mat[i][j] <= 100

此题可以用前缀和来做,但是比较难点儿的是边界不好控制!!接下来看看代码吧~

cpp 复制代码
class Solution {
public:
vector<vector<int>> sums;
    vector<vector<int>> matrixBlockSum(vector<vector<int>>& mat, int k) {
        int rlen=mat.size(),clen=mat[0].size();
        sums.resize(rlen+1,vector<int>(clen+1));//初始化空间
        for(int i=1;i<=rlen;i++){
            for(int j=1;j<=clen;j++){
                sums[i][j]=sums[i-1][j]+sums[i][j-1]-sums[i-1][j-1]+mat[i-1][j-1];//求前缀和
            }
        }
        vector<vector<int>> res(rlen,vector<int>(clen));//此处一定要初始化空间,否则报空指针
        for(int i=0;i<rlen;i++){
            for(int j=0;j<clen;j++){
                // 分别获取左上角和右下角的坐标
                int r1=max(i-k,0),c1=max(j-k,0);
                int r2=min(i+k,rlen-1),c2=min(j+k,clen-1);
                // 通过二维前缀和公式获取某个区间内的和
                res[i][j]=sums[r2+1][c2+1]-sums[r2+1][c1]-sums[r1][c2+1]+sums[r1][c1];
            }
        }
        return res;
    }
};

提交通过!

相关推荐
rainbow688910 小时前
C++STL list容器模拟实现详解
开发语言·c++·list
唐梓航-求职中10 小时前
技术-算法-leetcode-1606. 找到处理最多请求的服务器(易懂版)
服务器·算法·leetcode
啊阿狸不会拉杆10 小时前
《机器学习导论》第 10 章-线性判别式
人工智能·python·算法·机器学习·numpy·lda·线性判别式
会叫的恐龙10 小时前
C++ 核心知识点汇总(第11日)(排序算法)
c++·算法·排序算法
twilight_46910 小时前
机器学习与模式识别——线性回归算法
算法·机器学习·线性回归
玄同76510 小时前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm
Pluchon10 小时前
硅基计划4.0 算法 简单模拟实现位图&布隆过滤器
java·大数据·开发语言·数据结构·算法·哈希算法
符哥200810 小时前
C++ 适合初学者的学习笔记整理
c++·笔记·学习
独断万古他化10 小时前
【算法通关】前缀和:和为 K、和被 K整除、连续数组、矩阵区域和全解
算法·前缀和·矩阵·哈希表
历程里程碑10 小时前
普通数组-----除了自身以外数组的乘积
大数据·javascript·python·算法·elasticsearch·搜索引擎·flask