备战秋招版 --- 第12题:85.最大矩形

cpp 复制代码
class Solution {
public:
    int maximalRectangle(vector<vector<char>>& matrix) {
        int m=matrix.size(), n=matrix[0].size();
        vector<vector<int>> nums(matrix.size(),vector<int>(matrix[0].size()));
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(i==0){
                    nums[i][j]= matrix[i][j]=='1'?1:0;
                }else{
                    nums[i][j]= matrix[i][j]=='1'?nums[i-1][j]+1:0;
                }
            }
        }
        for(int i=0;i<m;i++){
            nums[i].push_back(-1);
        }
        int res=0;
        for(int i=0;i<m;i++){
            stack<int> stk;
            for(int j=0;j<=n;j++){
                while(!stk.empty()&&nums[i][j]<nums[i][stk.top()]){
                    int mid=stk.top(); stk.pop();
                    int left=stk.empty()?-1:stk.top();
                    int right=j;
                    res = max(res, nums[i][mid]*(right-left-1));
                }
                stk.push(j);
            }
        }
        return res;
    }
};
相关推荐
Bigger8 分钟前
🚀 真正实用的前端算法技巧:从 semver-compare 到智能版本排序
前端·javascript·算法
海梨花18 分钟前
【力扣Hot100】刷题日记
算法·leetcode·1024程序员节
DuHz1 小时前
使用稀疏采样方法减轻汽车雷达干扰——论文阅读
论文阅读·算法·汽车·信息与通信·信号处理
hansang_IR1 小时前
【算法速成课 3】康托展开(Cantor Expansion)/ 题解 P3014 [USACO11FEB] Cow Line S
c++·算法·状态压缩·康托展开·排列映射
m0_748233641 小时前
【类与对象(中)】C++类默认成员函数全解析
开发语言·c++·算法
scilwb1 小时前
STM32 实战:驯服失控的 M3508 电机 - PID 位置环频率的“坑”与“药”
算法·代码规范
chonbw1 小时前
226.翻转二叉树
算法·leetcode
周杰伦_Jay3 小时前
【 RocketMQ 全解析】分布式消息队列的架构、消息转发与快速实践、事务消息
分布式·算法·架构·rocketmq·1024程序员节
sprintzer3 小时前
10.16-10.25力扣计数刷题
算法·leetcode
王哈哈^_^3 小时前
【数据集】【YOLO】【目标检测】建筑垃圾数据集 4256 张,YOLO建筑垃圾识别算法实战训推教程。
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·数据集