题目链接:1314. 矩阵区域和

题目乍一看很晦涩难懂,又是大于等于又是k的
仔细分析,题目所说的意思就是以[i,j]为中心,求上下左右向外拓展k个单位的矩阵和,放在名为answer的矩阵中,最后返回answer矩阵即可
在填写结果矩阵的过程中,一个核心步骤是确定原矩阵中对应区域的“左上角”和“右下角”的坐标。为了更好地理解,建议大家通过画图来辅助。
通过这样的步骤,我们可以有效地确定原矩阵中对应区域的边界,进而进行后续的计算和填写结果矩阵的操作。
- class Solution
- {
- public:
- vector<vector<int>> matrixBlockSum(vector
>& mat, int k) - {
- int m = mat.size(), n = mat[0].size();
- vector<vector<int>> dp(m + 1, vector
(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];//减一为了匹配原来的mat
- vector<vector<int>> ret(m, vector
(n)); - for(int i = 0; i < m; i++)
- for(int j = 0; j < n; j++)
- {
- int x1 = max(0, i - k) + 1, y1 = max(0, j - k) + 1;
- int x2 = min(m - 1, i + k) + 1, y2 = min(n - 1, j + k) + 1;//加一为了匹配dp表
- ret[i][j] = dp[x2][y2] - dp[x1 - 1][y2] - dp[x2][y1 - 1] + dp[x1 - 1][y1 - 1];
- }
- return ret;
- }
- };
嗯,就是这样啦,文章到这里就结束啦,真心感谢你花时间来读。
觉得有点收获的话,不妨给我点个赞吧!
如果发现文章有啥漏洞或错误的地方,欢迎私信我或者在评论里提醒一声~