Leetcode--85. 最大矩形

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

示例:

输入:
[
  ["1","0","1","0","0"],
  ["1","0","1","1","1"],
  ["1","1","1","1","1"],
  ["1","0","0","1","0"]
]
输出:6

思路:动态规划

用dp二维数组保存每个位置以它结尾的,1的长度,例如dp[0][2]位置,1的长度为1,dp[2][4]位置,1的长度为5

知道各个位置以他结尾的1的长度之后,开始考虑矩形的宽度

以本题的结果为例,dp[2][4]长度为5,现在以他结尾的矩形面积max暂定为5,之后向上搜索,dp[1][4]长度为3,但是我们的高度增加了,所以现在面积是2*3=6,增大了,更新max为6即可。

提交的代码:

class Solution {
    public int maximalRectangle(char[][] matrix) {
            int n = matrix.length;
        int m=0;
        if(n>0)                                //题中有测试案例输入为空,因此直接写int m = matrix[0].length;会报错
        {
             m = matrix[0].length;
        }
        if(m==0&&n==0)
        {
            return 0;
        }
        int i,j,max=-1,t=0,k;
        int[][] dp1 = new int[n][m];
        for(i=0;i<n;i++)
        {
            for(j=0;j<m;j++)
            {
                if(matrix[0][0]=='1')
                {
                    dp1[0][0]=1;
                }
                else if(matrix[0][0]=='0')
                {
                    dp1[0][0]=0;
                }
                if(i==0&&j>0)
                {
                    if(matrix[i][j]=='1')
                    {
                        dp1[i][j] = dp1[i][j-1]+1;
                    }
                    else
                    {
                        dp1[i][j] = 0;
                    }
                }
                else if(j==0&&i>0)
                {
                    if(matrix[i][j]=='1')
                    {
                        dp1[i][j]=1;
                    }
                }
                else if(i>0&&j>0)
                {
                    if(matrix[i][j]=='1')
                    {
                        dp1[i][j] = dp1[i][j-1]+1;
                    }
                    else
                    {
                        dp1[i][j] = 0;
                    }
                }
                t = dp1[i][j];
                for(k=i;k>=0;k--)
                {
                    t = java.lang.Math.min(dp1[k][j], t);   //比较目前j列已经遍历过的行中,找到最小长度进行计算
                    if(t*(i-k+1)>max)
                    {
                        max = t*(i-k+1);
                    }
                }
            }
        }
        return max;
    }
}

完整代码:


public class Solution85 {
    public static int maximalRectangle(char[][] matrix) {
        int n = matrix.length;
        int m=0;
        if(n>0)
        {
             m = matrix[0].length;
        }
        if(m==0&&n==0)
        {
            return 0;
        }
        int i,j,max=-1,t=0,k;
        int[][] dp1 = new int[n][m];
        for(i=0;i<n;i++)
        {
            for(j=0;j<m;j++)
            {
                if(matrix[0][0]=='1')
                {
                    dp1[0][0]=1;
                }
                else if(matrix[0][0]=='0')
                {
                    dp1[0][0]=0;
                }
                if(i==0&&j>0)
                {
                    if(matrix[i][j]=='1')
                    {
                        dp1[i][j] = dp1[i][j-1]+1;
                    }
                    else
                    {
                        dp1[i][j] = 0;
                    }
                }
                else if(j==0&&i>0)
                {
                    if(matrix[i][j]=='1')
                    {
                        dp1[i][j]=1;
                    }
                }
                else if(i>0&&j>0)
                {
                    if(matrix[i][j]=='1')
                    {
                        dp1[i][j] = dp1[i][j-1]+1;
                    }
                    else
                    {
                        dp1[i][j] = 0;
                    }
                }
                t = dp1[i][j];
                for(k=i;k>=0;k--)
                {
                    t = java.lang.Math.min(dp1[k][j], t);
                    if(t*(i-k+1)>max)
                    {
                        max = t*(i-k+1);
                    }
                }
            }
        }
        return max;
    }
    public static void main(String[] args)
    {
        char[][] a = {{'1','0','1','0','0'},{'1','0','1','1','1'},{'1','1','1','1','1'},{'1','0','0','1','0'}};
        System.out.println(maximalRectangle(a));
    }
}
 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PowerDesigner生成sql语句时自动导出注释

1、为sql生成注释&#xff0c;操作如下&#xff0c;在其中选择Tools----》Excute commands-----》Edit/Run Script打开的窗口中添加以下信息 ****************************************************************************** * File: name2comment.vbs * Purpo…

为什么俄罗斯的数学那么牛?

编辑 ∑Gemini来源:奇趣数学苑但在国际上也有一个很著名的说法&#xff0c;就是世界上最好的大学&#xff0c;其实是“美国的学校&#xff0c;中国的学生&#xff0c;俄罗斯的教授”。俄罗斯数学家佩雷尔曼虽然俄罗斯现在相比以前来说&#xff0c;尤其明显的是在一些需要大量设…

查看屏幕大小_疑似“iPhone 12” 的OLED屏幕组件泄露

来自可靠的泄密者的新照片显示了即将面世的“ iPhone 12”所搭载的OLED屏幕。这名泄密者以前曾显示过未来苹果产品的准确图像&#xff0c;此前曾展示过苹果A14芯片组的早期图片&#xff0c;并声称“ iPhone 12”将配备20W电源适配器。现在他在推特上发布了一张照片&#xff0c;…

Leetcode--198. 打家劫舍

你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系统会自动报警。 给定一个代表每个房屋存放金额的…

搭建Hexo博客(一)-创建Hexo环境

Hexo配合github&#xff0c;可以创建自己的博客。基本原理是使用Hexo生成静态页面&#xff0c;发布到github上。在本地需要搭建Hexo环境。 1、安装nodejs 下载并安装NodeJS&#xff0c;官网地址&#xff1a;https://nodejs.org/en/ 2、安装完后&#xff0c;查看安装情况 1 node…

python logging模块的作用及应用场景_Python logging模块原理解析及应用

一、logging日志模块等级常见log级别从高到低&#xff1a;CRITICAL 》ERROR 》WARNING 》INFO 》DEBUG&#xff0c;默认等级为WARNING&#xff0c;即>WARNING级别的log才输出。日志等级(level)描述CRITICAL当发生严重错误&#xff0c;导致应用程序不能继续运行时记录的信息E…

Nature:2020年最佳科学影像,每一张都是壁纸,每一张都是历史

文章来源&#xff1a;学术头条2020年是独一无二的一年。COVID-19大流行将科学推到了最前沿&#xff0c;并深刻影响了人们的生活。但是这一年也产生了许多与病毒无关的新影像。从薄薄的太阳能电池&#xff0c;到经过基因编辑的鱿鱼&#xff0c;下面就是Nature新闻和艺术团队评选…

Leetcode--213. 打家劫舍Ⅱ

你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋&#xff0c;每间房内都藏有一定的现金。这个地方所有的房屋都围成一圈&#xff0c;这意味着第一个房屋和最后一个房屋是紧挨着的。同时&#xff0c;相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚…

转 从红帽、GitHub和Docker看开源商业模式的进阶

从红帽、GitHub和Docker看开源商业模式的进阶 发表于2014-12-16 10:26| 7594次阅读| 来源http://stratechery.com/| 0 条评论| 作者Ben ThompsonDocker红帽GitHub开源CoreOS摘要&#xff1a;从技术角度来说&#xff0c;Docker无疑是可圈可点的&#xff0c;比如“write once run…

antimalware可以关闭吗_iPhone最好关闭这4个设置,手机流畅还省电

你抢到新款的iPhone12了吗&#xff1f;80%的小伙伴都会忽略的设置&#xff0c;你的iPhone手机最好关闭以下这4个设置。①关闭ios系统更新操作步骤&#xff1a;打开【设置】-【通用】-【软件更新】-【自动更新】-【下载iOS更新】&#xff0c;关闭即可。这样就不会莫名其妙地下载…

Leetcode--221.最大正方形

在一个由 0 和 1 组成的二维矩阵内&#xff0c;找到只包含 1 的最大正方形&#xff0c;并返回其面积。 示例: 输入: 1 0 1 0 0 1 0 1 1 1 1 1 1 1 1 1 0 0 1 0 输出: 4 思路&#xff1a;和最大长方形类似&#xff08;可以参照https://mp.csdn.net/postedit/102420219&…

tableau连接mysql_tableau 连接mysql的操作步骤

一&#xff1a;下载并安装好以下应用程序&#xff1a;1.数据库mysql2.数据库管理工具navicat premium3.数据可视化工具tableau4.mysql对应版本的ODBC驱动包二&#xff1a;配置ODBC1.控制面板→系统和安全→管理工具中找到"数据源ODBC"&#xff0c;并启动它&#xff0…

MVVM Light Toolkit使用指南

原文地址&#xff1a; https://blog.csdn.net/ldld1717/article/details/77040077概述MVVM Light Toolkit是一个Android MVVM 轻量级工具库&#xff0c;主要目的是更快捷方便的构建Android MVVM应用程序&#xff0c;工具库添加了一些Data Binding 不支持的属性&#xff0c;还有…

段永朝:界面——之内、之外与之间

来源&#xff1a;苇草智酷01画一个圈儿&#xff0c;就把平面分成圈内&#xff0c;圈外。这个圈儿&#xff0c;就成了界面。垒一道墙&#xff0c;就把空间分成墙里&#xff0c;墙外。这个墙&#xff0c;就成了界面。看一眼手机上的钟表&#xff0c;那一刻闪现的数字&#xff0c;…

Leetcode--5. 最长回文子串

给定一个字符串 s&#xff0c;找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。 示例 1&#xff1a; 输入: "babad" 输出: "bab" 注意: "aba" 也是一个有效答案。 示例 2&#xff1a; 输入: "cbbd" 输出: "bb"…

mysql面试考点_mysql面试知识点

1 引擎-MyISAM和InnoDB的区别a 是否支持行级锁 :MyISAM 只有表级锁(table-level locking)&#xff0c;而InnoDB 支持行级锁(row-level locking)和表级锁,默认为行级锁。b 是否支持事务和崩溃后的安全恢复&#xff1a;MyISAM 强调的是性能&#xff0c;每次查询具有原子性,其执行…

jquery 快速入门二

---恢复内容开始--- 操作标签 样式操作 样式类 addClass();//添加指定的CSS类名。 removeClass();//移除指定的类名. hasClass();//判断样式不存在 toggleClass();//切换css类名&#xff0c;如果有就移除&#xff0c;如果没有就添加 示例&#xff1a;开关灯和模态框 CSS css(&q…

中国工程院《全球工程前沿2020》报告在京发布

来源&#xff1a;科学网作者&#xff1a;李晨阳12月18日上午&#xff0c;中国工程院《全球工程前沿2020》报告在京发布。报告围绕机械与运载工程、信息与电子工程、化工冶金与材料工程、能源与矿业工程、土木水利与建筑工程、环境与轻纺工程、农业、医药卫生、工程管理9个领域&…

Leetcode--279. 完全平方数

给定正整数 n&#xff0c;找到若干个完全平方数&#xff08;比如 1, 4, 9, 16, ...&#xff09;使得它们的和等于 n。你需要让组成和的完全平方数的个数最少。 示例 1: 输入: n 12 输出: 3 解释: 12 4 4 4. 示例 2: 输入: n 13 输出: 2 解释: 13 4 9. 思路&#xf…

java基础题集

1.什么是java虚拟机&#xff1f;为什么java被称作是“平台无关的编程语言”&#xff1f; java虚拟机是一个可以执行java字节码的虚拟机进程。java源文件被编译成能被java虚拟机执行的字节码文件。 java被设计成允许应用程序可以运行在任意的平台&#xff0c;而不需要程序员为每…