LeetCode 3070. 元素和小于等于 k 的子矩阵数目

LeetCode 3070. 元素和小于等于 k 的子矩阵数目

题目描述

给你一个大小为 m x n 的整数矩阵 grid 和一个整数 k。你需要找出 grid 中所有以左上角 (0,0) 为起始点的子矩阵,并统计这些子矩阵中元素和不超过 k 的个数。

注意 :子矩阵必须包含 (0,0) 这个格子,即子矩阵的左上角固定为原点,右下角可以是任意坐标 (i,j)0 <= i < m, 0 <= j < n)。

思路分析

本题的暴力做法是枚举所有可能的子矩阵,并计算其和,但时间复杂度会达到 O(m²n²),不可取。由于子矩阵的左上角固定,我们可以利用二维前缀和 来快速得到任意从 (0,0)(i,j) 的子矩阵的和。

二维前缀和

定义 s[i+1][j+1] 表示原矩阵中从 (0,0)(i,j) 的子矩阵的元素和。这样 s[i][j] 就对应了以 (i-1,j-1) 为右下角的子矩阵的和(左上角为 (0,0))。

前缀和的递推公式(容斥原理):

复制代码
s[i+1][j+1] = s[i+1][j] + s[i][j+1] - s[i][j] + grid[i][j]

其中 s[0][*]s[*][0] 均为 0,方便边界处理。

统计答案

构建完前缀和数组 s 后,我们只需要遍历所有可能的右下角坐标 (i,j)i 从 1 到 m,j 从 1 到 n),检查 s[i][j] <= k 是否成立,如果成立则答案加一。

代码实现

cpp 复制代码
class Solution {
public:
    int countSubmatrices(vector<vector<int>>& grid, int k) {
        int m = grid.size(), n = grid[0].size();
        // 二维前缀和数组,大小为 (m+1) x (n+1)
        vector<vector<int>> s(m + 1, vector<int>(n + 1, 0));
        
        // 构建前缀和
        for (int i = 0; i < m; ++i) {
            for (int j = 0; j < n; ++j) {
                s[i + 1][j + 1] = s[i + 1][j] + s[i][j + 1] - s[i][j] + grid[i][j];
            }
        }
        
        int ans = 0;
        // 枚举右下角
        for (int i = 1; i <= m; ++i) {
            for (int j = 1; j <= n; ++j) {
                if (s[i][j] <= k) ++ans;
            }
        }
        return ans;
    }
};

复杂度分析

  • 时间复杂度:O(m × n)。构建前缀和需要遍历所有格子,统计答案也需要遍历所有可能的右下角,因此总时间复杂度为 O(mn)。
  • 空间复杂度:O(m × n),用于存储二维前缀和数组。

总结

本题的核心是二维前缀和的应用。由于子矩阵的左上角固定为原点,前缀和数组可以直接对应每个可能子矩阵的和,从而将统计过程简化为一次遍历。掌握二维前缀和可以高效解决类似矩阵区域和的问题。

相关推荐
先吃饱再说13 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰16 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术17 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六20 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术21 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队2 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC2 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode