在一个由 0 和 1 组成的二维矩阵内,找到只包含 1 的最大正方形,并返回其面积。
示例:
输入:
1 0 1 0 0
1 0 1 1 1
1 1 1 1 1
1 0 0 1 0
输出: 4
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximal-square
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
dp[i][j]的意思,以matrix[i-1][j-1]为右下角的最大正方形的边长
dp[][]多开一行一列,方便第一行和第一列的统一处理
class Solution {
public int maximalSquare(char[][] matrix) {
if(matrix==null||matrix.length==0)
return 0;
int ans=0;
int r=matrix.length;
int c=matrix[0].length;
int dp[][]=new int[r+1][c+1];
for(int i=1;i<r+1;i++) {
for(int j=1;j<c+1;j++) {
if(matrix[i-1][j-1]=='1') {
dp[i][j]=1+Math.min(Math.min(dp[i-1][j-1],dp[i-1][j]),dp[i][j-1]);
ans=Math.max(ans,dp[i][j]);
}
}
}
return ans*ans;
}
}