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;
}
相关推荐
x_xbx2 小时前
LeetCode:19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
nananaij2 小时前
【LeetCode-05 好数对的数目 python解法】
python·算法·leetcode
一叶落4382 小时前
LeetCode 6. Z 字形变换(C语言详解)
c语言·数据结构·算法·leetcode
米粒13 小时前
力扣算法刷题 Day 15
算法·leetcode·职场和发展
Frostnova丶4 小时前
(10)LeetCode 560. 和为K的子数组
算法·leetcode·哈希算法
j_xxx404_5 小时前
LeetCode模拟算法精解II:外观数列与数青蛙
数据结构·c++·算法·leetcode
Tisfy6 小时前
LeetCode 3070.元素和小于等于 k 的子矩阵的数目:原地修改(前缀和思想)
算法·leetcode·前缀和·矩阵
喵喵蒻葉睦6 小时前
力扣 hot100 最小覆盖子串 哈希表 滑动窗口 Java 题解
java·算法·leetcode·哈希算法·散列表·滑动窗口
一叶落4387 小时前
【LeetCode 12】整数转罗马数字(C语言)| 贪心算法详解
c语言·数据结构·c++·算法·leetcode·贪心算法