221.M 最大正方形
题目
输入:matrix = [["1","0","1","0","0"],["1","0","1","1","1"],["1","1","1","1","1"],["1","0","0","1","0"]]
输出:4 输入:matrix = [["0","1"],["1","0"]]
输出:1 输入:matrix = [["0"]]
输出:0解题思路
实现代码
Last updated
输入:matrix = [["1","0","1","0","0"],["1","0","1","1","1"],["1","1","1","1","1"],["1","0","0","1","0"]]
输出:4 输入:matrix = [["0","1"],["1","0"]]
输出:1 输入:matrix = [["0"]]
输出:0Last updated
func maximalSquare(matrix [][]byte) int {
rows := len(matrix)
cols := len(matrix[0])
dp := make([][]int, rows)
for i := 0; i < rows; i++ {
dp[i] = make([]int, cols)
}
maxLen := 0
for i := 0; i < rows; i++ {
for j := 0; j < cols; j++ {
if matrix[i][j] == '1' {
if i == 0 || j == 0 {
dp[i][j] = 1
} else {
dp[i][j] = min(min(dp[i][j-1], dp[i-1][j-1]), dp[i-1][j]) + 1
}
if dp[i][j] > maxLen {
maxLen = dp[i][j]
}
}
}
}
return maxLen * maxLen
}
func min(a, b int) int {
if a <= b {
return a
}
return b
}