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;
}
相关推荐
6Hzlia15 分钟前
【Hot 100 刷题计划】 LeetCode 15. 三数之和 | C++ 排序+双指针
c++·算法·leetcode
北顾笙9802 小时前
day37-数据结构力扣
数据结构·算法·leetcode
6Hzlia4 小时前
【Hot 100 刷题计划】 LeetCode 189. 轮转数组 | C++ 三次反转经典魔法 (O(1) 空间)
c++·算法·leetcode
m0_629494735 小时前
LeetCode 热题 100-----13.最大子数组和
数据结构·算法·leetcode
田梓燊5 小时前
力扣:94.二叉树的中序遍历
数据结构·算法·leetcode
khalil10205 小时前
代码随想录算法训练营Day-38动态规划06 | 322. 零钱兑换、279.完全平方数、139.单词拆分、多重背包、总结
数据结构·c++·算法·leetcode·动态规划
阿Y加油吧5 小时前
二刷 LeetCode:300. 最长递增子序列 & 152. 乘积最大子数组 复盘笔记
笔记·算法·leetcode
6Hzlia5 小时前
Hot 100 刷题计划】 LeetCode 146. LRU 缓存 | C++ 哈希表+双向链表
c++·leetcode·缓存
我不是懒洋洋5 小时前
【数据结构】二叉树OJ(单值二叉树、检查两棵树是否相同、对称二叉树、二叉树的前序遍历、另一颗树的子树)
c语言·数据结构·c++·经验分享·算法·leetcode·visual studio
阿Y加油吧6 小时前
二刷 LeetCode:5. 最长回文子串 & 1143. 最长公共子序列 复盘笔记
笔记·算法·leetcode