LeetCode 题解:85. Maximal Rectangle

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

解题思路

这道题的解题思路和前面的84题相近(Largest Rectangle in Histogram),可以理解为将此题中的二维数组的每一行当做是84题中的一维的高度统计数组,那么统计二维矩阵中面积最大的长方形,就可以转变为先求每一个一维统计数组的最大矩形面积,然后求所有统计数组求得的矩形的面积的最大值。
具体算法如下:
1.建立记录数组dp[n][m+1],此处的m+1是为了求最大矩形面积时能够有一个终止位置(类似84题),所以要比原二维数组多一列
2.每一个统计数组的元素的值为该位置所对应的二维数组的列从当前行往上遍历能够得到的最长连续“1”序列的长度,若没有连续“1”序列,则赋为0。
3.利用84题中计算最大矩形面积的算法为每一个统计数组记录它能得到的最大矩形面积(84题算法
4.取(3)中得到的所有矩形面积中的最大值作为最终答案

C++代码

class Solution {
public:
    int calculateMaxArea(vector<int>& heights) {
        stack<int> rec;
        int res = 0;
        for(int i = 0; i < heights.size();) {
            if(rec.empty() || heights[rec.top()] <= heights[i]) {
                rec.push(i);
                i++;
            }
            else {
                int r = rec.top();
                rec.pop();
                res = max(res, heights[r] * (rec.empty()? i : i - rec.top() - 1));
            }
        }
        return res;
    }
    
    int maximalRectangle(vector<vector<char>>& matrix) {
        if(matrix.size() == 0 || matrix[0].size() == 0)
            return 0;
        vector<vector<int>> dp(matrix.size(), vector<int>(matrix[0].size()+1));
        int res = 0;
        
        for(int i = 0; i < matrix[0].size(); i++) {
            dp[0][i] = matrix[0][i] == '0'? 0 : 1;
            for(int j = 1; j < matrix.size(); j++) {
                dp[j][i] = matrix[j][i] == '1'? dp[j-1][i]+1 : 0;
            }
        }

        for(int i = 0; i < dp.size(); i++) {
            int r = calculateMaxArea(dp[i]);
            res = max(res, r);
        }
        return res;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
CSDN IT狂飙上传的代码均可运行,功能ok的情况下才上传的,直接替换数据即可使用,小白也能轻松上手 【资源说明】 基于MATLAB实现的有限差分法实验报告用MATLAB中的有限差分法计算槽内电位;对比解析法和数值法的异同点;选取一点,绘制收敛曲线;总的三维电位图+使用说明文档 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2020b;若运行有误,根据提示GPT修改;若不会,私信博主(问题描述要详细); 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可后台私信博主; 4.1 期刊或参考文献复现 4.2 Matlab程序定制 4.3 科研合作 功率谱估计: 故障诊断分析: 雷达通信:雷达LFM、MIMO、成像、定位、干扰、检测、信号分析、脉冲压缩 滤波估计:SOC估计 目标定位:WSN定位、滤波跟踪、目标定位 生物电信号:肌电信号EMG、脑电信号EEG、心电信号ECG 通信系统:DOA估计、编码译码、变分模态分解、管道泄漏、滤波器、数字信号处理+传输+分析+去噪、数字信号调制、误码率、信号估计、DTMF、信号检测识别融合、LEACH协议、信号检测、水声通信 5、欢迎下载,沟通交流,互相学习,共同进步!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZTao-z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值