当前位置: 首页 > news >正文

85.最大矩形

在这里插入图片描述
在这里插入图片描述
单调栈,时间复杂度o(mn),空间复杂度o(mn)

class Solution {
public:int maximalRectangle(vector<vector<char>>& matrix) {int m=matrix.size();if(m==0){return 0;}int n=matrix[0].size();//记录矩阵中每个元素左边连续1的数量vector<vector<int>> left(m,vector<int>(n,0));for(int i=0;i<m;i++){for(int j=0;j<n;++j){if(matrix[i][j]=='1'){left[i][j]=(j==0?0:left[i][j-1])+1;}}}int ret=0;//对于每一列,使用基于柱状图的方法,leetcode84for(int j=0;j<n;j++){vector<int> up(m,0),down(m,0);stack<int> stk;for(int i=0;i<m;++i){while(!stk.empty()&&left[stk.top()][j]>=left[i][j]){stk.pop();}up[i]=stk.empty()?-1:stk.top();stk.push(i);}stk=stack<int>();for(int i=m-1;i>=0;i--){while(!stk.empty()&&left[stk.top()][j]>=left[i][j]){stk.pop();}down[i]=stk.empty()?m:stk.top();stk.push(i);}for(int i=0;i<m;++i){int height=down[i]-up[i]-1;int area=height*left[i][j];ret=max(ret,area);}}return ret;}
};
http://www.lryc.cn/news/184315.html

相关文章:

  • Windows服务器 开机自启动服务
  • 《算法通关之路》chapter17一些通用解题模板
  • 常用求解器安装
  • 第三章:最新版零基础学习 PYTHON 教程(第一节 - Python 运算符)
  • 细粒度特征提取和定位用于目标检测:PPCNN
  • 【STM32单片机】数学自动出题器设计
  • C语言之动态内存管理篇(1)
  • React18入门(第二篇)——React18+Ts项目配置husky、eslint、pretttier、commitLint
  • 【VINS】苹果手机采集单目相机+IMU数据离线运行VINS-Mono
  • 数据结构 2.1 单链表
  • [Machine Learning]pytorch手搓一个神经网络模型
  • KdMapper扩展实现之Dell(pcdsrvc_x64.pkms)
  • python和go相互调用的两种方法
  • c# 分部视图笔记
  • Vue3最佳实践 第七章 TypeScript 中
  • (三)行为模式:8、状态模式(State Pattern)(C++示例)
  • nginx的配置文件概述及简单demo(二)
  • Apollo Planning2.0决策规划算法代码详细解析 (2): vscode gdb单步调试环境搭建
  • flex 布局:元素/文字靠右
  • java基础-第1章-走进java世界
  • jvm 堆内存 栈内存 大小设置
  • 免杀对抗-反沙盒+反调试
  • QTimer类的使用方法
  • (三)行为模式:9、空对象模式(Null Object Pattern)(C++示例)
  • Django实战项目-学习任务系统-用户登录
  • 【动手学深度学习-Pytorch版】Transformer代码总结
  • 做外贸独立站选Shopify还是WordPress?
  • echarts的bug,在series里写tooltip,不起作用,要在全局先写tooltip:{}才起作用,如果在series里写的不起作用就写到全局里
  • jmeter分布式压测
  • consulmanage部署