LeetCode221. 最大正方形

在一个由 '0' 和 '1' 组成的二维矩阵内,找到只包含 '1' 的最大正方形,并返回其面积。

 

输入:matrix = [["1","0","1","0","0"],["1","0","1","1","1"],["1","1","1","1","1"],["1","0","0","1","0"]]
输出:4

class Solution {
    public int maximalSquare(char[][] matrix) {
        //思路:对矩阵当中的位置i,j,dp[i,j]代表以该点作为正方形的右下角时正方形的最大边长
        //该点由其左角、上角和左上角共同决定,取其三角的最小值+1,即是该点的dp值
      int ans = 0, n = matrix.length, m = matrix[0].length;
        int[][] dp = new int[n+1][m+1];
        for(int i = 1; i <= n; ++i)
        {
            for(int j = 1; j <= m; ++j)
            {
                if(matrix[i-1][j-1] == '1')
                    dp[i][j] = Math.min(Math.min(dp[i-1][j], dp[i][j-1]), dp[i-1][j-1])+1;
                ans = Math.max(ans, dp[i][j]);
            }
        }
        return ans*ans;
    }
}

 

posted @ 2021-04-07 08:58  γGama  阅读(50)  评论(0编辑  收藏  举报