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

给你一个下标从 0 开始的整数矩阵 grid 和一个整数 k

返回包含 grid 左上角元素、元素和小于或等于 k子矩阵的数目。

示例 1:

复制代码
输入:grid = [[7,6,3],[6,6,1]], k = 18
输出:4
解释:如上图所示,只有 4 个子矩阵满足:包含 grid 的左上角元素,并且元素和小于或等于 18 。

示例 2:

复制代码
输入:grid = [[7,2,9],[1,5,0],[2,6,6]], k = 20
输出:6
解释:如上图所示,只有 6 个子矩阵满足:包含 grid 的左上角元素,并且元素和小于或等于 20 。

提示:

  • m == grid.length
  • n == grid[i].length
  • 1 <= n, m <= 1000
  • 0 <= grid[i][j] <= 1000
  • 1 <= k <= 10^9

分析:求出二维前缀和,统计有多少个和的值小于等于 k 即可。

cpp 复制代码
int countSubmatrices(int** grid, int gridSize, int* gridColSize, int k) {
    int n=gridSize,m=gridColSize[0],ans=0,sum[n+5][m+5];
    if(grid[0][0]>k)return 0;
    else ans=1;
    sum[0][0]=grid[0][0];
    for(int i=1;i<n;++i)
    {
        sum[i][0]=sum[i-1][0]+grid[i][0];
        if(sum[i][0]<=k)ans++;
    }
    for(int i=1;i<m;++i)
    {
        sum[0][i]=sum[0][i-1]+grid[0][i];
        if(sum[0][i]<=k)ans++;
    }
    for(int i=1;i<n;++i)
        for(int j=1;j<m;++j)
        {
            sum[i][j]=grid[i][j]-sum[i-1][j-1]+sum[i-1][j]+sum[i][j-1];
            if(sum[i][j]<=k)ans++;
        }
            
    return ans;
}
相关推荐
阿Y加油吧14 小时前
两道字符串 DP 模板题复盘:最长公共子序列 & 编辑距离
leetcode
我爱cope15 小时前
【力扣hot100:76. 最小覆盖子串】
算法·leetcode·职场和发展
sheeta199815 小时前
LeetCode 每日一题笔记 日期:2026.05.20 题目:2657. 找到前缀公共数组
笔记·算法·leetcode
吃着火锅x唱着歌16 小时前
LeetCode 962.最大宽度坡
算法·leetcode·职场和发展
凌波粒16 小时前
LeetCode--257. 二叉树的所有路径(二叉树)
算法·leetcode·职场和发展
阿Y加油吧17 小时前
两道数组算法题复盘:多数元素 & 颜色分类
算法·leetcode·职场和发展
And_Ii18 小时前
LeetCode 026. 重排链表
算法·leetcode·链表
是娇娇公主~18 小时前
力扣——146.LRU缓存详解
算法·leetcode·缓存
_深海凉_18 小时前
LeetCode热题100-路径总和 III
算法·leetcode·职场和发展
YL2004042619 小时前
054实现Trie(前缀树)
数据结构·leetcode