【刷题记录 python】最大正方形

leetcode 221
关键:
(1)dp数组:遍历matrix中的每个元素,站在以遍历时的每个元素为正方形右下角的角度,dp在每个元素对应的位置上取正方形的边长为值。所以dp维度和matrix一样,元素取值含义为:以该元素为右下角的最正方形的边长
(2)递推公式:要确定正方形右下角元素对应的最大正方形边长,依赖该元素左边、上面、左上三个位置在dp数组中的取值。

  • matrix[i][j] == “1” : dp[i][j] = min(dp[i-1][j],dp[i][j-1],dp[i-1][j-1]) + 1
  • 否则为0
    (3)初始化:递推公式涉及到-1的计算,因此初始化dp的第0行和第0列,当matrix对应元素为“1”时,dp对应位置取值为1
    (4)遍历顺序:因为递推公式考虑左、上、左上三个方向,因此按正序顺序遍历即可保证遍历到当前位置时,dp数组中左、上、左上位置的值已经更新过了。
class Solution:
    def maximalSquare(self, matrix: List[List[str]]) -> int:
        r, c = len(matrix)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值