美文网首页
5454. 统计全 1 子矩形

5454. 统计全 1 子矩形

作者: Pandarum | 来源:发表于2020-07-06 00:49 被阅读0次

题目

5454. 统计全 1 子矩形

给你一个只包含 0 和 1 的 rows * columns 矩阵 mat ,请你返回有多少个 子矩形 的元素全部都是 1 。

示例 1:
输入:**mat = [[1,0,1],
[1,1,0],
[1,1,0]]
输出:13
解释:6 个 1x1 的矩形。
2 个 1x2 的矩形。
3 个 2x1 的矩形。
1 个 2x2 的矩形。
1 个 3x1 的矩形。
矩形数目总共 = 6 + 2 + 3 + 1 + 1 = 13

示例 2:
输入:**mat = [[0,1,1,0],
[0,1,1,1],
[1,1,1,0]]
输出:24
解释:
8 个 1x1 的子矩形。
5 个 1x2 的子矩形。
2 个 1x3 的子矩形。
4 个 2x1 的子矩形。
2 个 2x2 的子矩形。
2 个 3x1 的子矩形。
1 个 3x2 的子矩形。
矩形数目总共 = 8 + 5 + 2 + 4 + 2 + 2 + 1 = 24

示例 3:
输入:mat = [[1,1,1,1,1,1]]
输出:21

示例 4:
输入:mat = [[1,0,1],[0,1,0],[1,0,1]]
输出:5

本题是7月5号周赛第三题,比赛时完全没有思路。赛后参考其他大神的题解才理解。下面说一下现在的理解。

题目说找全1的子矩阵,也就是统计在确定的边界之内的数字是否都为1。

  1. 对于矩阵题目通常可以考虑确定两个边界来简化题目。假设矩阵为 n * m,对于给定的上下边界row_lowrow_hight(此时矩阵高度为row_hight - row_low + 1,假设索引从0开始),然后我们从0 -> m开始遍历column。因为row会覆盖所有的行,所有我们固定row后,只需要考虑column。如图
    image.png
  2. 对于给定高度,遍历column,当所在列全部为1是,矩形为符合要求的子矩形;否则不符合要求。假设row_low = 1, row_high=2
    1- col=0此时高度为2的矩形有1个(cnt=1),更新ans里;当col从0->1时高度为row_high - row_low + 1的矩形有3个(1, 0) -> (2, 0),(1, 1) -> (2, 2), (1, 0) -> (2, 2),col从0变为1贡献了2个矩形(cnt++),累加到ans里;当col从1->2贡献3个矩形(cnt++),可以总结当col从m->m+1切col全部为1时贡献cnt++个矩形,累加到ans里。
    2- 当col对于的数字不全为1时,则需要重置cnt=0,因为在给定的row_low, row_high以及col无法形成新的子矩形。继续遍历col,重复2.1步骤。
  3. 为了方便判断2.1和2.2的条件可以添加一个sum数组辅助判断。
    最后给出Java代码:
public int numSubmat(int[][] mat) {
    int n = mat.length;
    int m = mat[0].length;
    int[] sum = new int[m], int ans = 0;
    for (int i = 0; i < n; i++) {
        Arrays.fill(sum, 0);  // 每次i变更是需要重置sum,因为此时sum里面的值不可用了
        for (int j = i; j < n; j++) {
            for (int k = 0; k < m; k++) {
                sum[k] += mat[j][k]; // j每迭代一次更新一下sum[k],如图中当i=1&j=1是将第1行更新到sum中;当j=2是将第2行迭代至sum中
            }
            int cnt = 0, high = j - i + 1;
            for (int k = 0; k < m; k++) {
                if (sum[k] == high) {
                    cnt++;
                    ans += cnt;
                } else {
                    cnt = 0;
                }
            }
        }
    }
    return ans;
}

相关文章

  • 5454. 统计全 1 子矩形

    题目 5454. 统计全 1 子矩形 给你一个只包含 0 和 1 的 rows * columns 矩阵 mat ...

  • 直方图最大面积矩形&01矩阵中最大的全0(1)矩阵

    求直方图中最大矩形的面积,用这个思路可以进一步解决求01矩阵中最大的全0或全1矩阵 直方图中最大矩形的面积 问题描...

  • android View坐标系:getX/getTranslat

    图中灰色矩形是320X480屏幕区域,绿色矩形是300X300的父View,实线黄色矩形是100X100的子Vie...

  • 《剑指offer》— JavaScript(10)矩形覆盖

    矩形覆盖 题目描述 我们可以用(2*1)的小矩形横着或者竖着去覆盖更大的矩形。请问用n个(2*1)的小矩形无重叠地...

  • 循环-矩形覆盖-java

    循环-矩形覆盖 题目描述 我们可以用2×1 的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地...

  • iOS 矩形识别

    需求:识别图片中的矩形框,标出矩形区域,并可以裁剪矩形区域 实现方式: 1、使用CIDetector类识别矩形区域...

  • 剑指Offer上两个一样的题

    1.我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,...

  • UIView & UIWindow & CALayer

    1、UIView属于UIKit Framework,负责渲染矩形区域的内容,为矩形区域添加动画,响应矩形区域的触摸...

  • GEE区域统计

    影像图斑统计功能实现 主要功能 对SRTM数据的特定范围完成空间统计,输出指定矩形范围内的最大值 代码 步骤分析 ...

  • PS小知识

    1、制作圆角图形 (1)通过平滑选区制作圆角矩形选区 选择矩形选框工具,绘制一个矩形选框 选择选择菜单>修改>平滑...

网友评论

      本文标题:5454. 统计全 1 子矩形

      本文链接:https://www.haomeiwen.com/subject/qqtiqktx.html