LeetCode 85. 最大矩形

预备知识

84.柱状图中最大的矩形:题目链接

思路:在求柱状图最大面积时,我们可以枚举每一根柱子,并且假设这根柱子就是最大面积中最低的那一根柱子。由于最大面积的选中的柱子中,矩形的高取决于最低的柱子,现在已知矩形的高,知道矩形的宽即可求出最大矩形面积。矩形的宽如何求呢?如果我们对每一根柱子A,可以知道在左边第一个低于他的柱子是B,在右边第一个低于他的柱子是C,那么这两根柱子之间的柱子一定都高于等于柱子A,矩形的宽就为C-B-1。

我们可以开一个栈(存柱子的编号),并维护从栈顶到栈底,柱子高度是从高到低的,在遍历时会有以下几种情况:

  1. 当前柱子a 低于栈顶柱子b,那么可以得知柱子b右边第一个比他低的柱子就是a
  2. 当前柱子a 高于栈顶柱子b,那么可以得知:柱子b左边第一个比他低的柱子就是a
  3. 栈为空,说明左边没有比他低的柱子。
class Solution {
public:int largestRectangleArea(vector<int>& heights) {int n = heights.size();vector<int> l(n), r(n);stack<int>stk;int ans = 0;for(int i=0;i<n;i++){while(!stk.empty() && heights[i] < heights[stk.top()]){r[stk.top()] = i;stk.pop();}if(stk.empty()) l[i] = -1;else l[i] = stk.top();stk.push(i);}while(!stk.empty()){r[stk.top()] = n;stk.pop();}for(int i=0;i<n;i++){ans = max(ans,heights[i]*(r[i]-l[i]-1));}return ans;}
};

思路

想法1:按照上面的思路,枚举每一列,然后求得左边连续的长度和右边连续的长度,以这条边作为矩形的宽计算。但这种方法并不行,因为左右不一定都取最长,因为在一边取最长的前提下,另一边也取最长可能会影响矩形的高度,反而使矩形达不到最大。

思路:其实只需要求得左边连续的长度即可,换一种角度想,我枚举每一列时,其实是在枚举最大矩阵的优边界,那么即使我只计算了这一列左半部分的矩阵面积,右半部分的面积没有计算,显然不是最大矩阵。但是我可以在枚举下一列时,得到更大的面积,直到枚举到最大矩阵右边界的那一列,可以得到最大面积,这个最大面积就是右边界那一列左半部分的面积,无需再向右延伸。

class Solution {
public:int maximalRectangle(vector<vector<char>>& matrix) {int n = matrix.size();int m = matrix[0].size();int ans = 0;vector<vector<int>> l(n,vector<int>(m,0));// 计算左边连续了多少个1for(int i=0;i<n;i++)for(int j=0;j<m;j++)if(matrix[i][j] == '1')l[i][j] = j ? l[i][j-1] + 1 : 1;elsel[i][j] = 0;stack<int> stk;vector<int> up(n), down(n);for(int j=0;j<m;j++){for(int i=0;i<n;i++){while(!stk.empty() && l[i][j] < l[stk.top()][j])down[stk.top()] = i , stk.pop();if(!stk.empty()) up[i] = stk.top();else up[i] = -1;stk.push(i);}while(!stk.empty()){down[stk.top()] = n;stk.pop();}for(int i=0;i<n;i++)ans = max(ans, l[i][j]*(down[i]-up[i]-1));}return ans;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/2676.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Java Collections工具类

Collections 类:Java 中提供的一组静态方法&#xff0c;用于操作集合。常用方法: 1. 排序 Collections.sort(List<T> list) 对指定列表进行升序排序。 Arrays.asList 将一个数组转化为一个List集合 List<Integer> numbers Arrays.asList(5, 2, 8, 1); Collections…

MCU+RTOS调试

1. 引言在做项目时&#xff0c;百分之三十的时间写代码&#xff0c;还有百分之70的时间用于调试。本期将以Keil为例进行调试章节的讲解&#xff0c;目的在于做出一个标准化的调试步骤&#xff0c;方便大家学习如何调试代码。内容分为基础调试、中级调试及进阶调试三部分&#x…

基于STM32F103的FM1702驱动程序

基于STM32F103微控制器与复旦微电子FM1702SL射频读卡芯片的驱动开发方案&#xff0c;整合了硬件配置、寄存器操作和通信协议实现&#xff1a;一、硬件连接设计 1. 管脚映射表FM1702SL引脚STM32F103引脚功能说明VDD3.3V电源输入GNDGND地线SCKPA5(SPI1_SCK)SPI时钟MISOPA6(SPI1_M…

Zabbix 6.0 监控AWS全栈实战|EC2至Lambda的无缝监控

一、云监控架构挑战与突破传统云监控痛点&#xff1a; ❌ 多区域/多账户资源分散难统一 ❌ 无服务器环境监控盲区&#xff08;Lambda/API Gateway&#xff09; ❌ 云账单爆炸式增长Zabbix-AWS解决方案&#xff1a;三层监控体系&#xff1a;基础设施层&#xff1a;EC2/EBS/VPC&a…

深入Go并发编程:Channel、Goroutine与Select的协同艺术

在现代软件开发中&#xff0c;并发编程已成为提升程序性能和响应能力的关键。Go语言作为一门为并发而生的现代编程语言&#xff0c;其简洁而强大的并发模型&#xff0c;特别是goroutine和channel&#xff0c;为开发者提供了优雅的并发解决方案。本文将深入探讨Go并发编程的核心…

nvim编辑器

安装lazy.nvim -- 在 ~/.config/nvim/init.lua 中添加以下代码 -- 设置 leader 键&#xff08;推荐空格&#xff09; vim.g.mapleader " "-- 加载 lazy.nvim local lazypath vim.fn.stdpath("data") .. "/lazy/lazy.nvim" if not vim.loop.fs_…

Android启动时间优化大全

1 修改Android mksh默认的列长度 不修改这个参数&#xff0c;adb shell后&#xff0c;输入超过80个字符&#xff0c;就不能看到完整的命令行。external/mksh/src/sh.h EXTERN mksh_ari_t x_cols E_INIT(80); EXTERN mksh_ari_t x_lins E_INIT(24);2 Kernel优化 2.1 内核驱动模块…

JavaScript核心概念全解析

目录 1. 作用域 (1) 局部作用域 (2) 全局作用域 2. 垃圾回收 (1) 引用计数法 (2) 标记清除法 3. 闭包 (1) 作用 (2) 风险 4. 变量提升 (1) var (2) let 和 const (3) const 5. 函数提升 (1) 函数声明 (2) 函数表达式 6. 函数参数 (1) 动态参数 (2) 剩余参数…

Red靶机攻略

一.环境准备 1.1Red靶机环境准备 1.1.1首先将我们解压好的的jangow-01-1.0.1.ova放入虚拟机里&#xff0c;并配置环境。安装好靶机后打开进行配置&#xff0c;按住shift&#xff0c;在界面按e进去得到图二。 1.1.2按住ctrlx&#xff0c;ip a查看网卡信息,修改网络配置文件 /e…

Linux之shell脚本篇(三)

一、 for循环使用基础语法for var in 数据域&#xff08;表达式&#xff09; do 语句1 done 代码案例1.循环3次hello world &#xff0c;打印循环池内容#!/bin/bash for i in www.jd.com www.qq.com www.4399.com do echo $i hello world.done 2.ping 网段范围内地址(1)打印网段…

9-大语言模型—Transformer 核心:多头注意力的 10 步拆解与可视化理解

目录 1、Transformer编码器堆叠的每层结构 2、输入嵌入 3、位置编码 4、多头注意力层 4.1、步骤1&#xff1a;表示输入 4.1.1、输入 4.1.2、示意图 ​编辑 4.2、步骤2&#xff1a;初始化权重矩阵 4.2.1、初始化Query权重矩阵&#xff1a; 4.2.2、初始化Key权重矩阵…

Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现标签条码一维码的检测(C#代码,UI界面版)

Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现标签条码一维码的检测&#xff08;C#代码&#xff0c;UI界面版&#xff09;&#xff09;工业相机使用YoloV8模型实现标签条码一维码的检测工业相机通过YoloV8模型实现标签条码的检测的技术背景在相机SDK中获取图像转换…