Leetcode85 01矩阵中的最大矩形

题目描述

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

解题思路

动态规划的思想,记录每一个位置向上能到达的最大高度,和向左能到达的最大宽度。

在一个点进行遍历时,向左走该点的最大宽度,

每走一步记录当前的最大高度并计算此时的最大面积。

代码实现

java 复制代码
class Solution {
    public int maximalRectangle(char[][] matrix) {
        int m=matrix.length;
        if(m == 0) return 0;
        int n=matrix[0].length;
        int max=0;
        int[][][] dp=new int[m][n][2];
        // 0-> width 1->height
        if(matrix[0][0]=='1'){
            dp[0][0][0]=1;
            dp[0][0][1]=1;
            max=1;
        }
        for (int i=1;i<n;i++){
            if(matrix[0][i]=='1'){
                dp[0][i][0]=dp[0][i-1][0]+1;
                dp[0][i][1]=1;
                max=Math.max(max,dp[0][i][0]);
            }
        }
        for (int i=1;i<m;i++){
            if(matrix[i][0]=='1'){
                dp[i][0][1]=dp[i-1][0][1]+1;
                dp[i][0][0]=1;
                max=Math.max(max,dp[i][0][1]);
            }
        }
        for (int i=1;i<m;i++){
            for (int j=1;j<n;j++){
                if(matrix[i][j]=='1'){
                    dp[i][j][0]=dp[i][j-1][0]+1;
                    dp[i][j][1]=dp[i-1][j][1]+1;
                    int width=dp[i][j][0],height=dp[i][j][1],minHeight=height;
                    for (int k=1;k<=width;k++){
                        minHeight=Math.min(minHeight,dp[i][j-k+1][1]);
                        max=Math.max(max,k*minHeight);
                    }
                }
            }
        }
        return max;
    }
}
相关推荐
百***060120 小时前
五大消息模型介绍(RabbitMQ 详细注释版)
java·rabbitmq·java-rabbitmq
Coovally AI模型快速验证20 小时前
去噪扩散模型,根本不去噪?何恺明新论文回归「去噪」本质
人工智能·深度学习·算法·机器学习·计算机视觉·数据挖掘·回归
歌_顿20 小时前
attention、transform、bert 复习总结 1
人工智能·算法
转转技术团队20 小时前
MyBatis-Plus踩坑血泪史:那些年我们踩过的坑!
java·面试·mybatis
MicroTech202520 小时前
MLGO微算法科技时空卷积与双重注意机制驱动的脑信号多任务分类算法
科技·算法·分类
sg_knight21 小时前
IntelliJ IDEA 实用插件:GitToolBox 使用指南
java·ide·git·intellij-idea·插件·gittoolbox
青云交21 小时前
Java 大视界 -- Java 大数据机器学习模型在电商用户画像构建与精准营销中的应用
java·大数据·机器学习·电商·协同过滤·用户画像·精准营销
txp玩Linux21 小时前
rk3568上解析webrtc音频降噪算法处理流程
算法·音视频·webrtc
z***677721 小时前
Spring EL 表达式的简单介绍和使用
java·后端·spring
立志成为大牛的小牛21 小时前
数据结构——五十二、散列函数的构造(王道408)
数据结构·笔记·程序人生·考研·算法