0221. Maximal Square
Last updated
Last updated
**Input:** matrix = [["1","0","1","0","0"],["1","0","1","1","1"],["1","1","1","1","1"],["1","0","0","1","0"]]
**Output:** 4**Input:** matrix = [["0","1"],["1","0"]]
**Output:** 1**Input:** matrix = [["0"]]
**Output:** 0class Solution {
public int maximalSquare(char[][] matrix) {
int max = 0;
for (int r = 0; r < matrix.length; r++) {
for (int c = 0; c < matrix[0].length; c++) {
if (matrix[r][c] == '0') continue;
if (r - 1 >= 0 && c - 1 >= 0) {
int min = Math.min(Math.min(matrix[r-1][c-1] - '0', matrix[r-1][c] - '0'), matrix[r][c-1] - '0');
matrix[r][c] = (char)('0' + min + 1);
}
max = Math.max(max, matrix[r][c] - '0');
}
}
return max * max;
}
}