动态规划4:最大子段和问题到最大子矩阵问题(四):最大子矩阵面积问题
2014-02-01 21:23
295 查看
上文讲的是从二维矩阵(r*c),找出它的一个子矩阵,使得这个子矩阵内的所有元素之和最大
但是这个矩形的大小不一定是最大的,现在我们来找一个最大面积的子矩阵
转自:《浅谈用极大化思想解决最大子矩形问题》
问题1:来看LeetCode上的一道题:LeetCode OJ:Maximal Rectangle
题意是:给一个只有0和1元素的矩阵,从中找出一个最大的子矩阵,满足矩阵内只包含1
这显然不是求最大子矩阵和问题,是最大子矩阵面积问题
算法思想:
对于matrix[i][j]=1,找到上边离i最远且连续的位置H,左边最靠近j的最远1的位置L,并不是离j最远的1,同样找到右边最靠近j的最远位置R,result=max{result,H*(R-L)}
如果每次都对i,j处的元素都找上面元素,左边及右边元素,重复劳动太多,可以用数组来保存
对于matrix[i][j]=1,
H[i][j]表示以第i行为子矩阵的底边的子矩阵高度,及从此元素向上连续的1的个数,有H[i][j]=H[i-1][j]+1;
L[i][j]表示左边最靠近j的最远1的位置,有L[i][j]=max{L[i-1][j],离j位置左边最远的1的位置}
R[i][j]表示右边最靠近j的最远1的位置,有R[i][j]=min{R[i-1][j],离j位置右边最远的1的位置}
else
H[i][j]=0;
L[i][j]=0;
R[i][j]=n
根据i与i-1之间的关系,可以将二维数组化为一维数组处理
![](http://www.freeimagehosting.net/newuploads/989su.jpg)
但是这个矩形的大小不一定是最大的,现在我们来找一个最大面积的子矩阵
转自:《浅谈用极大化思想解决最大子矩形问题》
问题1:来看LeetCode上的一道题:LeetCode OJ:Maximal Rectangle
题意是:给一个只有0和1元素的矩阵,从中找出一个最大的子矩阵,满足矩阵内只包含1
这显然不是求最大子矩阵和问题,是最大子矩阵面积问题
算法思想:
对于matrix[i][j]=1,找到上边离i最远且连续的位置H,左边最靠近j的最远1的位置L,并不是离j最远的1,同样找到右边最靠近j的最远位置R,result=max{result,H*(R-L)}
如果每次都对i,j处的元素都找上面元素,左边及右边元素,重复劳动太多,可以用数组来保存
对于matrix[i][j]=1,
H[i][j]表示以第i行为子矩阵的底边的子矩阵高度,及从此元素向上连续的1的个数,有H[i][j]=H[i-1][j]+1;
L[i][j]表示左边最靠近j的最远1的位置,有L[i][j]=max{L[i-1][j],离j位置左边最远的1的位置}
R[i][j]表示右边最靠近j的最远1的位置,有R[i][j]=min{R[i-1][j],离j位置右边最远的1的位置}
else
H[i][j]=0;
L[i][j]=0;
R[i][j]=n
根据i与i-1之间的关系,可以将二维数组化为一维数组处理
![](http://www.freeimagehosting.net/newuploads/989su.jpg)
class Solution { public: int maximalRectangle(vector<vector<char> > &matrix) { if(matrix.empty())return 0; int len=matrix[0].size(); vector<int> H(len); vector<int> L(len); vector<int> R(len,len); int result=0; for(int i=0;i<matrix.size();i++){ int left=0,right=len; for(int j=0;j<len;j++){ if(matrix[i][j]=='1'){ H[j]++; L[j]=max(L[j],left); } else{ left=j+1; H[j]=0;L[j]=0;R[j]=len; } } for(int j=len-1;j>=0;j--){ if(matrix[i][j]=='1'){ R[j]=min(R[j],right); result=max(result,H[j]*(R[j]-L[j])); } else right=j; } } return result; } };
相关文章推荐
- 动态规划3:最大子段和问题到最大子矩阵问题(三):初探最大子矩阵之和问题
- ACM——最大子矩阵问题——单位矩阵
- 【动态规划】最大子段和问题,最大子矩阵和问题,最大m子段和问题
- HDU1505、2870,2830(最大的10矩阵面积问题)
- 数组与矩阵---子矩阵的最大累加和问题
- 动态规划1:最大子段和问题到最大子矩阵问题(一):最大子段和问题详谈
- 动态规划2:最大子段和问题到最大子矩阵问题(二):最大n子段和问题详谈
- 最大子段和||最大子矩阵和||最大全1子矩阵||最大全1子正方形||
- 最大子段和||最大子矩阵和||最大全1子矩阵||最大全1子正方形||
- uva1330 在一个大的矩阵中寻找面积最大的子矩阵
- 0013算法笔记——【动态规划】最大子段和问题,最大子矩阵和问题,最大m子段和问题
- 直方图下的矩阵最大面积问题
- 0013算法笔记——【动态规划】最大子段和问题,最大子矩阵和问题,最大m子段和问题
- 最大子矩阵问题;枚举行的组合,然后利用一维最大子段和的DP算法;
- 华为机考 给你一个N*M的矩阵,每个位置的值是0或1,求一个面积最大的子矩阵,这个矩阵必须是一个正方形,且里面只能由1构成,输出最大的正方形边长。其中n,m<=400;
- 0013算法笔记——【动态规划】最大子段和问题,最大子矩阵和问题,最大m子段和问题
- 最大子段和问题,最大子矩阵和问题,最大m子段和问题
- 【dp基础课程】矩阵取数问题+最大子段和+最长公共子序列(LCS)【51nod】
- 最大子段和问题,最大子矩阵和问题,最大m子段和问题
- POJ 1050 To the Max(dp 最大子矩阵和/最大子段和问题)