最大矩阵——单调栈

给定一个由 01 组成的矩阵 matrix ,找出只包含 1 的最大矩形,并返回其面积。

注意: 此题 matrix 输入格式为一维 01 字符串数组。

示例 1:

复制代码
输入:matrix = ["10100","10111","11111","10010"]
输出:6
解释:最大矩形如上图所示。

思路:

我们首先计算出矩阵的每个元素的左边连续 1 的数量,使用二维数组oneHeight 记录,其中oneHeightij 为矩阵第 i 行第 j 列元素的左边连续 1 的数量。

接下来是对84题柱状图中最大的矩形------单调栈的集大成者-CSDN博客 的轻微进阶。对每一列都按84题处理,即求以当前列为底的最大矩形面积。遍历所有列后求得全局最大面积。

python 复制代码
from typing import List


class Solution:
    def maximalRectangle(self, matrix: List[str]) -> int:
        if len(matrix) == 0 or len(matrix[0]) == 0:
            return 0
        m,n=len(matrix),len(matrix[0])
        oneHeight = [[0 for _ in range(n)] for _ in range(m)]
        for i in range(m):
            for j in range(n):
                if matrix[i][j] == '1':
                    before=oneHeight[i][j - 1] if j > 0 else 0
                    oneHeight[i][j] = before + 1
        res=0
        for j in range(n):
            stack = []
            leftMin=[-1]*m
            rightMin=[m]*m
            for i in range(m):
                while stack and oneHeight[stack[-1]][j]> oneHeight[i][j]:
                    i1=stack.pop()
                    rightMin[i1]=i
                leftMin[i]=stack[-1] if stack else -1
                stack.append(i)
            for i in range(m):
                res=max(res,(rightMin[i]-leftMin[i]-1)*oneHeight[i][j])
        return res


print(Solution().maximalRectangle(["1"]))
相关推荐
花酒锄作田3 小时前
Pydantic校验配置文件
python
hboot4 小时前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
罗西的思考7 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营9 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队10 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
ZhengEnCi14 小时前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi16 小时前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽16 小时前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户83580861879117 小时前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode