难度:困难
给定一个仅包含 0 和 1 的二维二进制矩阵,找出只包含 1 的最大矩形,并返回其面积。
示例:
输入:
[
["1","0","1","0","0"],
["1","0","1","1","1"],
["1","1","1","1","1"],
["1","0","0","1","0"]
]
输出: 6
结果
执行用时 :
24 ms, 在所有 cpp 提交中击败了 85.19%的用户
内存消耗 :
11.9 MB, 在所有 cpp 提交中击败了 28.90%的用户
分析
这也是一个多解法问题,先写一篇占个坑吧。
目前的这个解法相当于是动态规划和 No.84 的缝合怪。。。
代码
class Solution {
public:
int maximalRectangle(vector<vector<char>>& matrix) {
if(matrix.size() == 0 || matrix[0].size() == 0) return 0;
int n = matrix.size(), m = matrix[0].size(),res=0;
vector<vector<int> > vec(n,vector<int>(m,0));
for(int i = 0; i < m; ++i)
if(matrix[0][i] == '1') vec[0][i] = 1;
for(int i = 0; i < m; ++i)
for(int j = 1; j < n; ++j)
if(matrix[j][i] == '1')
vec[j][i] = vec[j-1][i] + 1;
for(int i = 0; i < n; ++i)
res = max(largestRectangleArea(vec[i]),res);
return res;
}
int largestRectangleArea(vector<int>& heights) {
if(heights.size() == 0) return 0;
int n = heights.size(),res = heights[0],record;
stack<int> st;
st.push(-1);
for(int i = 0; i < n; ++i){
while(st.top()!=-1 && heights[i] < heights[st.top()]){
int tmp = st.top();
st.pop();
res = max(heights[tmp] * (i - st.top() - 1),res);
}
st.push(i);
}
while(st.top()!=-1){
int tmp = st.top();
st.pop();
res = max(heights[tmp] * (n - st.top() - 1),res);
}
return res;
}
};
后记
有些话,说出来就好了。