LeetCode 85. Maximal Rectangle

简介: 题意是给定一个二维的零一矩阵,1可以用来围成一些矩阵,题意要求是返回围城矩阵的面积最大值.

v2-8363f6ad44c6531371d4566b8aba4215_1440w.jpg

Description



Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing only 1's and return its area.


Example:


Input:

[

["1","0","1","0","0"],

["1","0","1","1","1"],

["1","1","1","1","1"],

["1","0","0","1","0"]

]

Output: 6


描述



  • 题意是给定一个二维的零一矩阵,1可以用来围成一些矩阵,题意要求是返回围城矩阵的面积最大值.


v2-aa7ed874edcaeb218839163ea780c8c5_720w.jpg


  • 如上图,此题是第84题的转换题.84题在这里,解析在这里.
  • 我们将每一层都转换成为一个条形矩阵,转换的规则是:如果当前位置是1,将当前位置以及当前位置随对应列的上面所有的1相加,直到遇到第一个0为止,如果当前位置是0,则直接置为0.
  • 这样已转换就成了和84题一样的题目.
  • 二维矩阵的每一行都是一个84题的heights,我们返回其最大值即可.


# -*- coding: utf-8 -*-
# @Author:             何睿
# @Create Date:        2018-12-24 19:51:30
# @Last Modified by:   何睿
# @Last Modified time: 2018-12-24 21:26:32
class Solution:
    # 这道题利用了思路转换,将矩阵转换成为了条形图.
    def maximalRectangle(self, matrix):
        """
        :type matrix: List[List[str]]
        :rtype: int
        """
        # 如果矩阵为空,返回0
        if not matrix:
            return 0
        # 获取矩阵的行数,列数
        row, col = len(matrix), len(matrix[0])
        # 高度矩阵,同84题中的高度矩阵(柱状图)
        heights = [0 for _ in range(col)]
        # 最终返回的记过,初始化为0
        res = 0
        # 遍历每一行
        for i in range(row):
            for j in range(col):
                # 生成高度图
                # 如果当前位置是"1",则高度加1
                if int(matrix[i][j]) == 1:
                    heights[j] += 1
                # 如果当前位置是0,则高度置为0,不论当前位置对应上面是否有"1"
                # 只要当前位置是0,则该位置的柱状图就是0.
                else:
                    heights[j] = 0
            # 调用子方法,此方法解决的问题为84题所问的问题.
            temp = self.largestRectangleArea(heights)
            # 取较大的结果
            res = res if res > temp else temp
        return res
    def largestRectangleArea(self, heights):
        # 栈,该矩阵的左边界,当前柱状图索引,矩阵右边界,结果
        stack, leftborder, current, rightborder, res = [], 0, 0, 0, 0
        for i in range(len(heights)):
            # 如果矩阵为空或者当前height[i]比栈顶索引对应的高度高则压入栈
            if not stack or heights[i] >= heights[stack[-1]]:
                stack.append(i)
            else:
                # 只要height[i]比栈顶元素小且栈不为空则一直循环
                while stack and heights[i] < heights[stack[-1]]:
                    # 取出栈顶元素
                    current = stack.pop()
                    # 如果刚才取出的栈顶元素和此时的栈顶元素相等
                    # 则可以继续取栈顶元素,因为紧挨相同元素所觉决定的矩阵左右边界相等
                    while stack and heights[current] == heights[stack[-1]]:
                        current = stack.pop()
                    # height[current]矩阵的左边界为栈顶元素的索引
                    # 右边界为当前元素,其宽度为i-leftbofer-1
                    leftborder = stack[-1] if stack else -1
                    # 计算当前矩阵的面积
                    temp = (i-leftborder-1)*heights[current]
                    # 返回较大值
                    res = temp if temp > res else res
                # 把当前元素压入栈顶
                stack.append(i)
        # 如果栈不为空,就处理剩余的元素.
        if stack:
            # 此时剩下的所有元素的右边界是栈顶元素+1,并且在循环的过程中保持不变.
            rightborder = stack[-1]+1
            while stack:
                # 取出栈顶元素
                current = stack.pop()
                # 左边界为此时的栈顶元素索引,如果栈顶元素不存在则为-1
                leftborder = stack[-1] if stack else -1
                # 计算当前面积
                temp = (rightborder-leftborder-1)*heights[current]
                # 取较大值
                res = res if res > temp else temp
        return res
if __name__ == "__main__":
    so = Solution()
    res = so.maximalRectangle([
        [1, 0, 1, 0, 0],
        [1, 0, 1, 1, 1],
        [1, 1, 1, 1, 1],
        [1, 0, 0, 1, 0]
    ])
    print(res)


源代码文件在这里.


目录
相关文章
LeetCode 836. 矩形重叠 Rectangle Overlap
LeetCode 836. 矩形重叠 Rectangle Overlap
LeetCode 836. 矩形重叠 Rectangle Overlap
LeetCode 221. Maximal Square
在一个由 0 和 1 组成的二维矩阵内,找到只包含 1 的最大正方形,并返回其面积。
65 0
LeetCode 221. Maximal Square
Leetcode-Hard 84. Largest Rectangle in Histogram
Leetcode-Hard 84. Largest Rectangle in Histogram
106 0
Leetcode-Hard 84. Largest Rectangle in Histogram
LeetCode之Construct the Rectangle
LeetCode之Construct the Rectangle
78 0
LeetCode 223 Rectangle Area(矩形面积)
版权声明:转载请联系本人,感谢配合!本站地址:http://blog.csdn.net/nomasp https://blog.csdn.net/NoMasp/article/details/50593348 翻译 找到在二维平面中两个相交矩形的总面积。
825 0
|
3月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行