LeetCode P221---最大正方形 动态规划实现

题目来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximal-square
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

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

示例:

输入:

1 0 1 0 0
1 0 1 1 1
1 1 1 1 1
1 0 0 1 0

输出: 4

一开始看到这个题,,emmm以为是找最大连着的区域,,,,8说了,栽了一跟头。读题还是不够仔细啊……

然后冷静分析,回想起之前用到过的动态规划,这个题用得上

用maxSide记录所找到的只包含1最大的正方形边长,用dp[]记录以每个位置为正方形右下角的正方形边长,,
具体dp为:
dp = min( dp[i][j-1] , dp[i-1][j]) , dp[i-1][j-1] ) + 1
也就是每个位置的dp值为其左边、上边、左上一个的dp的最小值,还要加上1,因为要加上当前的

接下来就是要考虑特殊情况了:
就是当i、j的值为0时,即处于边界位置,那么此时dp的值最多只能为1了。

情况分析完毕,上代码:

/**
     * 在一个由 0 和 1 组成的二维矩阵内,找到只包含 1 的最大正方形,并返回其面积。
     * 动态规划
     * @param matrix
     * @return
     */
    public int maximalSquare(char[][] matrix) {
        //初始化最大边长为0
        int maxSide = 0;
        //如果矩阵是空的,或者没有元素,直接返回0
        if (matrix == null || matrix.length == 0 || matrix[0].length == 0){
            return maxSide;
        }
        //矩阵的行数
        int r = matrix.length;
        //矩阵的列数
        int c = matrix[0].length;
        //定义数组记录每个位置对应的最大边长数,,
        //dp[i][j] = min(Math.min(dp[i][j-1], dp[i-1][j]), dp[i-1][j-1]) + 1
        //特别的,当i=0或j=0,,dp[i][j]最大只能为1,,因为i-1,j-1超出了边界
        int[][] dp = new int[r][c];
        for (int i = 0; i < r; i++) {
            for (int j = 0; j < c; j++) {
                //遍历数组,如果碰到元素值为'1'的时候
                if (matrix[i][j] == '1'){
                    if (i == 0 || j == 0){
                        dp[i][j] = 1;//特殊情况,i、j刚好在边界
                    } else {
                        //动态规划
                        dp[i][j] = Math.min(Math.min(dp[i][j-1], dp[i-1][j]), dp[i-1][j-1]) + 1;
                    }
                }
                //更新最大边长值
                maxSide = Math.max(maxSide , dp[i][j]);
            }
        }
        //根据边长返回面积
        return maxSide * maxSide;
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值