最大矩形
2022/11/08
示例
示例一
输入:matrix = [["1","0","1","0","0"],["1","0","1","1","1"],["1","1","1","1","1"],["1","0","0","1","0"]]
输出:6
解释:最大矩形如上图所示。
示例二
输入:matrix = []
输出:0
示例三
输入:matrix = [["0"]]
输出:0
示例四
输入:matrix = [["1"]]
输出:1
示例五
输入:matrix = [["0","0"]]
输出:0
题解参考
使用柱状图的优化暴力方法
var maximalRectangle = function (matrix) {
const m = matrix.length;
if (m === 0) {
return 0;
}
const n = matrix[0].length;
const left = new Array(m).fill(0).map(() => new Array(n).fill(0));
for (let i = 0; i < m; i++) {
for (let j = 0; j < n; j++) {
if (matrix[i][j] === "1") {
left[i][j] = (j === 0 ? 0 : left[i][j - 1]) + 1;
}
}
}
let ret = 0;
for (let i = 0; i < m; i++) {
for (let j = 0; j < n; j++) {
if (matrix[i][j] === "0") {
continue;
}
let width = left[i][j];
let area = width;
for (let k = i - 1; k >= 0; k--) {
width = Math.min(width, left[k][j]);
area = Math.max(area, (i - k + 1) * width);
}
ret = Math.max(ret, area);
}
}
return ret;
};