085 Maximal Rectangle 最大矩形
给定一个填充了 0 和 1 的二进制矩阵,找到最大的只包含 1 的矩形并返回其面积。
例如,给出以下矩阵:
1 0 1 0 0
1 0 1 1 1
1 1 1 1 1
1 0 0 1 0
返回 6
详见:https://leetcode.com/problems/maximal-rectangle/description/
Java实现:
class Solution {
    public int maximalRectangle(char[][] matrix) {
        if(matrix == null || matrix.length == 0 || matrix[0].length == 0){
            return 0;
        }
        int res = 0;
        int m = matrix.length;
        int n = matrix[0].length;
        int [] heights = new int[n];
        for(int i = 0; i<m; i++){
            for(int j = 0; j<n; j++){
                heights[j] = matrix[i][j] == '0' ? 0 : heights[j]+1;
            }
            res = Math.max(res, largestRectangleArea(heights));
        }
        return res;
    }
    private int largestRectangleArea(int[] heights) {
        int res=0;
        int n=heights.length;
        for(int i=0;i<n;++i){
            if(i+1<n&&heights[i]<=heights[i+1]){
                continue;
            }
            int minH=heights[i];
            for(int j=i;j>=0;--j){
                minH=Math.min(minH,heights[j]);
                int area=minH*(i-j+1);
                res=Math.max(res,area);
            }
        }
        return res;
    }
}
参考:https://www.cnblogs.com/grandyang/p/4322667.html
085 Maximal Rectangle 最大矩形的更多相关文章
- [LintCode] Maximal Rectangle 最大矩形
		Given a 2D boolean matrix filled with False and True, find the largest rectangle containing all True ... 
- [LeetCode] Maximal Rectangle 最大矩形
		Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and ... 
- [LeetCode] 85. Maximal Rectangle 最大矩形
		Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing only 1's and ... 
- 【LeetCode】085. Maximal Rectangle
		题目: Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing only 1's ... 
- Java for LeetCode 085 Maximal Rectangle
		Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and ... 
- 求解最大矩形面积 — leetcode 85. Maximal Rectangle
		之前切了道求解最大正方形的题,题解猛戳 这里.这道题 Maximal Rectangle 题意与之类似,但是解法完全不一样. 先来看这道题 Largest Rectangle in Histogram ... 
- 最大的矩形面积 Maximal Rectangle
		2018-09-15 10:23:44 一.Largest Rectangle in Histogram 在求解最大的矩形面积之前,我们先讨论一条最大直方图面积的问题. 问题描述: 问题求解: 解法一 ... 
- LeetCode 84--柱状图中最大的矩形( Largest Rectangle in Histogram)   85--最大矩形(Maximal Rectangle)
		84题和85五题 基本是一样的,先说84题 84--柱状图中最大的矩形( Largest Rectangle in Histogram) 思路很简单,通过循环,分别判断第 i 个柱子能够延展的长度le ... 
- 【leetcode】Maximal Rectangle
		Maximal Rectangle Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle conta ... 
随机推荐
- php-循环普通数组和关联数组
			<?php //循环普通数组 $arr=array("杭州","成都","拉萨"); $arrlength=count($arr); ... 
- html5--5-11 绘制文字
			html5--5-11 绘制文字 学习要点 掌握文字的绘制方法 文字的绘制方法 strokeText("文字",x,y,maxWith) 绘制(描边)空心文字 fillText(& ... 
- ubuntu中使用gensim+word2vec[备忘]
			python版本: 2.7.12 0. 安装python和pip 1. 用pip依次安装: numpy, cython,scipy,pattern,word2vec 五个工具包 2. 用pip安装ge ... 
- 卸载asterisk 会装就要会卸载 你会吗? [跟我一起学](转安静的发狂者)
			1 针对用编译的方式安装时的卸载 第一步 :先停止你的asterisk >asterisk -rx ‘stop now’然后要验证一下是否真的被停了. >ps aux|grep “as ... 
- P1816 忠诚
			题目描述 老管家是一个聪明能干的人.他为财主工作了整整10年,财主为了让自已账目更加清楚.要求管家每天记k次账,由于管家聪明能干,因而管家总是让财主十分满意.但是由于一些人的挑拨,财主还是对管家产生了 ... 
- Persistent connections CONN_MAX_AGE  django
			Persistent connections¶ Persistent connections avoid the overhead of re-establishing a connection to ... 
- hihoCoder2月29日(字符串模拟)
			时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定两个日期,计算这两个日期之间有多少个2月29日(包括起始日期). 只有闰年有2月29日,满足以下一个条件的年份为闰年: ... 
- synergy的配置使用
			1.http://blog.csdn.net/qq_16618179/article/details/54094636 2.两个版本要一致 3.synergy fail to connect sec ... 
- 获取access_token时却报出下列错误信息:{"errcode":40164,"errmsg":"invalid ip 61.172.68.219, not in whitelist hint: [KJZfAa0644e575]"},以及一些其他报错
			获取access_token时却报出下列错误信息:{"errcode":40164,"errmsg":"invalid ip 61.172.68.21 ... 
- python使用ftplib做ftp操作
			ftplib是 Python的内置的一个标准模块,它提供了极强大的对FTP服务器的操作,通过它我们可以连接并操作FTP服务端,开始练习: 一.导入模块并进行连接 >>> from f ... 
