博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode OJ:Maximal Rectangle(最大矩形)
阅读量:6230 次
发布时间:2019-06-21

本文共 1534 字,大约阅读时间需要 5 分钟。

Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and return its area.

求出0,1矩阵中的最大矩形区域:

DP问题,可以使用数组记下当前行位置之前的所有1的个数,然后用一个三重循环来找以(i,j)为右下角的矩形的最大的面积,比较得到最大值。这样做复杂度还是比较高的。但是胜在简单,代码如下所示:

1 class Solution { 2 public: 3     int maximalRectangle(vector
>& matrix) { 4 if(matrix.size() == 0 || matrix[0].size() == 0) 5 return 0; 6 int szRow = matrix.size(); 7 int szCol = matrix[0].size(); 8 vector
> dp(szRow, vector
(szCol, 0));//表示当前行前面含有的1的个数 9 for(int i = 0; i < szRow; ++i){ //第一列的每一行的第一个元素10 dp[i][0] = matrix[i][0] == '1' ? 1 : 0; 11 }12 for(int i = 0; i < szRow; ++i){ //后面每列的每行的每个元素13 for(int j = 1; j < szCol; ++j){14 dp[i][j] = matrix[i][j] == '1' ? dp[i][j-1]+1 : 0;15 }16 }17 int maxVal = 0;18 for(int i = 0; i < szRow; ++i){19 for(int j = 0; j < szCol; ++j){20 int width = INT_MAX;21 for(int k = i; k >=0 ; --k){22 if(dp[k][j] == 0)23 break;24 width = min(width, dp[k][j]);//求出每次正方形的宽度25 maxVal = max(maxVal, width * (i - k + 1));//宽度乘以高度26 }27 }28 }29 return maxVal;30 }31 };

 先马一下,感觉写的挺好的,有时间在来写一下

转载于:https://www.cnblogs.com/-wang-cheng/p/5027219.html

你可能感兴趣的文章
excel 使用 navicat 导入数据库
查看>>
我的友情链接
查看>>
我的大学——我在科创协会的部长感悟
查看>>
数据结构之队列——顺序存储结构(php代码实现——方法一)
查看>>
Hive安装使用
查看>>
JDK 11的新特性
查看>>
MySQL优化20条经验(一)
查看>>
Linux修改时区
查看>>
ubuntu之R攻略
查看>>
《跟阿铭学Linux》第11章 正则表达式:课后习题与答案
查看>>
[软考]挣值管理EVM详细解释及应用,实例讲解收集(信息系统项目管理师-成本管理)...
查看>>
业内人士详述SIEM建设的演进过程
查看>>
数据中心的重要服务器如何保护?
查看>>
Linux 用户的 3 个命令行小技巧
查看>>
yii上传图片、yii上传文件、yii控件activeFileField使用
查看>>
8)基础网络编程和内容回顾
查看>>
Promise 入门(推荐)
查看>>
java jdbc使用配置文件连接数据库
查看>>
ASP.NET MVC中三方登录: 微软、谷歌、Office365
查看>>
迭代器模式
查看>>