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;
    }
}
相关推荐
木昜先生3 分钟前
知识点:深入理解 JVM 内存管理与垃圾回收
java·jvm·后端
115432031q6 分钟前
基于SpringBoot+Vue实现的旅游景点预约平台功能十三
java·前端·后端
战族狼魂10 分钟前
基于SpringBoot+PostgreSQL+ROS Java库机器人数据可视化管理系统
java·spring boot·postgresql
半个脑袋儿16 分钟前
Java线程控制: sleep、yield、join深度解析
java
小智疯狂敲代码21 分钟前
Spring MVC-DispatcherServlet 的源码解析
java·面试
int0x0321 分钟前
Java中的内存"瘦身术":揭秘String Deduplication
java
半个脑袋儿22 分钟前
Java日期格式化中的“YYYY”陷阱:为什么跨年周会让你的年份突然+1?
java·后端
Blossom.11827 分钟前
量子计算在密码学中的应用与挑战:重塑信息安全的未来
人工智能·深度学习·物联网·算法·密码学·量子计算·量子安全
1白天的黑夜132 分钟前
贪心算法-860.柠檬水找零-力扣(LeetCode)
c++·算法·leetcode·贪心算法
CHQIUU35 分钟前
Java 设计模式心法之第25篇 - 中介者 (Mediator) - 用“中央协调”降低对象间耦合度
java·设计模式·中介者模式