85-最大矩阵

题目

给定一个仅包含 0 和 1 、大小为 rows x cols 的二维二进制矩阵,找出只包含 1 的最大矩形,并返回其面积。

示例 1:

输入:matrix = \["1","0","1","0","0","1","0","1","1","1","1","1","1","1","1","1","0","0","1","0"]

输出:6

解释:最大矩形如上图所示。

示例 2:

输入:matrix = \[\]

输出:0

示例 3:

输入:matrix = \["0"]

输出:0

示例 4:

输入:matrix = \["1"]

输出:1

示例 5:

输入:matrix = \["0","0"]

输出:0

思路

最大矩形面积问题可以使用栈来解决,结合柱状图的特性。下面我将详细解释解题思路,并提供关键算法和算法思想的说明。

解题思路:

对于每一行,我们可以将每个元素的值视为当前位置向上的高度。我们可以根据每一行的高度构建一个柱状图,然后使用栈来计算柱状图中的最大矩形面积。

  1. 对于每一行,我们构建一个高度数组 heights,其中 heights[j] 表示从当前行的第 j 列向上的连续 1 的数量。我们可以根据上一行的高度数组和当前行的元素来更新这个数组。

  2. 对于 heights 数组,我们使用栈来辅助计算最大矩形面积。我们遍历 heights 数组,如果当前高度大于栈顶高度,就将当前索引入栈。否则,我们弹出栈顶索引,并计算以该高度为高的矩形面积,宽度为当前索引与弹出索引之间的距离。我们不断更新最大面积,直到栈为空或者当前高度大于栈顶高度。

关键算法和算法思想:

栈是解决这个问题的关键算法思想。通过使用栈,我们可以维护一个递增的高度序列,当遇到下降的高度时,我们可以计算以当前高度为高的矩形面积,利用栈中保存的索引信息。

代码

scala 复制代码
object Solution {
    def maximalRectangle(matrix: Array[Array[Char]]): Int = {
        if (matrix.isEmpty) return 0
        
        val rows = matrix.length
        val cols = matrix(0).length
        var maxArea = 0
        val heights = Array.fill(cols)(0)
        
        def largestRectangleArea(heights: Array[Int]): Int = {
            val stack = collection.mutable.Stack[Int]()
            var maxArea = 0
            
            for (i <- 0 until heights.length) {
                while (stack.nonEmpty && heights(i) < heights(stack.top)) {
                    val height = heights(stack.pop())
                    val width = if (stack.isEmpty) i else i - stack.top - 1
                    maxArea = math.max(maxArea, height * width)
                }
                stack.push(i)
            }
            
            while (stack.nonEmpty) {
                val height = heights(stack.pop())
                val width = if (stack.isEmpty) heights.length else heights.length - stack.top - 1
                maxArea = math.max(maxArea, height * width)
            }
            
            maxArea
        }
        
        for (i <- 0 until rows) {
            for (j <- 0 until cols) {
                if (matrix(i)(j) == '1') heights(j) += 1
                else heights(j) = 0
            }
            maxArea = math.max(maxArea, largestRectangleArea(heights))
        }
        
        maxArea
    }
}

// 示例
val matrix = Array(
    Array('1','0','1','0','0'),
    Array('1','0','1','1','1'),
    Array('1','1','1','1','1'),
    Array('1','0','0','1','0')
)
val result = Solution.maximalRectangle(matrix)
println(result) // 输出:6
相关推荐
YuK.W21 分钟前
Leetcode100: 94.二叉树中序遍历、104.二叉树最大深度、226.翻转二叉树
java·算法·leetcode·二叉树
气泡音人声分离1 小时前
技术解析|均衡器(EQ)工作原理与实操指南:从频率拆分到听感优化
算法·均衡器·音频剪辑
weixin_413063212 小时前
复现 MatchED 边缘检测模型(单张图片重复8次,训练200 epoch)
python·算法·计算机视觉·边缘检测模型
2601_962440842 小时前
计算机毕业设计之jsp教室管理系统
java·开发语言·笔记·分布式·算法·课程设计·推荐算法
AI视频剪辑官2 小时前
播客切片工具选型核心评价维度
网络·人工智能·算法
复杂网络4 小时前
AI 不睡觉,但它比你更会做实验
算法
贵慜_Derek5 小时前
MAI-04|干净数据在工程上意味着什么:MAI 预训练数据治理
人工智能·算法·llm
棒球1号位6 小时前
《棒球1号位矩阵联盟:江西青少年棒球基地建设的破局之道》
线性代数·矩阵
会博通·代码搬运工6 小时前
会博通数字化智能工作站(龟仔家族):产品矩阵、部署架构与技术选型指南
运维·数据库·线性代数·矩阵·架构·api集成·电子档案合规