在乙個由 0 和 1 組成的二維矩陣內,找到只包含 1 的最大正方形,並返回其面積。
示例:輸入:
1 0 1 0 0
1 0 1 1 1
1 1 1 1 1
1 0 0 1 0
輸出: 4
dp水題
dp[i][j]表示以matrix[i][j]為右下角的頂點的可組成最大正方形的邊長
classsolution:
def maximalsquare(self, matrix: list[list[str]]) ->int:
res=0
m=len(matrix)
if m==0:
return
0 n=len(matrix[0])
dp=[[0]*(n+1) for i in range(m+1)]
for i in range(1,m+1):
for j in range(1,n+1):
dp[i][j]=min(dp[i-1][j],dp[i][j-1],dp[i-1][j-1])+1 if matrix[i-1][j-1]=="1"
else
0 res=max(res,dp[i][j])
return res**2
221 最大正方形
在乙個由 0 和 1 組成的二維矩陣內,找到只包含 1 的最大正方形,並返回其面積。輸入 1 0 1 0 0 1 01 11 1 11 11 1 0 0 1 0輸出 4動態規劃。1 狀態方程dp i j 表示右下角下標為 i,j 時的最大正方形邊長。當遇到0時,dp i j 0,肯定不能構成正方形 ...
221 最大正方形
在乙個由 0 和 1 組成的二維矩陣內,找到只包含 1 的最大正方形,並返回其面積。示例 輸入 1 0 1 0 0 1 0 1 1 1 1 1 1 1 1 1 0 0 1 0 輸出 4 當我們判斷以某個點為正方形右下角時最大的正方形時,那它的上方,左方和左上方三個點也一定是某個正方形的右下角,否則該...
221 最大正方形
若某格仔值為1,則以此為右下角的正方形的 最大邊長為 上面的正方形 左面的正方形或左上的正方形中,最小的那個,再加上此格。dp i 1 j 1 表示 以第i行 第j列為右下角的正方形的最大邊長 假設補充了多一行全 0 多一列全 0 dp陣列的大小也明確為new dp height 1 width 1...