LeetCode如何实现最大正方形
发表于:2024-10-27 作者:千家信息网编辑
千家信息网最后更新 2024年10月27日,这篇文章将为大家详细讲解有关LeetCode如何实现最大正方形,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1题目描述0 和 1 组成一个字符型二维矩阵,在其中找到
千家信息网最后更新 2024年10月27日LeetCode如何实现最大正方形思路:动态规划 在LeetCode刷题DAY 2:最长回文子串中我们介绍了动态规划的含义,本次不再赘述,直接进入逻辑阐述。
这篇文章将为大家详细讲解有关LeetCode如何实现最大正方形,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
1
题目描述
0 和 1 组成一个字符型二维矩阵,在其中找到只包含 1 的最大正方形,并返回其面积。如:输入
[["1","0","1","0","0"],
["1","0","1","1","1"],
["1","1","1","1","1"],
["1","0","0","1","0"]]
返回4。
2
题解
第一步,找到中间状态:此处中间状态st[i][j]表示以矩阵中(i,j)元素作为正方形右下角顶点,可以得到最大正方形边长。
第二步,确定状态转移:如果(i,j)为0,则当前位置状态值为0,否则状态值取决于其上面、左面和左上角状态值,转移关系为st[i][j]=min(st[ist[i][j]=min(st[i-1][j],st[i-1][j-1],st[i][j-1])+1,即周围最小状态值+1。不理解的可以找个案例手动算一下。且要注意的是,如果该元素在整个矩阵的最外边,则状态值仅根据该元素取值判断即可。
class Solution: def maximalSquare(self, matrix: List[List[str]]) -> int: if len(matrix)==0: return 0 # len(matrix)得到的是矩阵行数 st = [[0]*len(matrix[0]) for _ in range(len(matrix))] maxlong = [] for i in range(len(matrix)): for j in range(len(matrix[0])): if matrix[i][j]=='1': if i*j==0: st[i][j]=1 else: st[i][j]=min(st[i-1][j],st[i-1][j-1],st[i][j-1])+1 maxlong.append(max(st[i])) return max(maxlong)**2
关于"LeetCode如何实现最大正方形"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
状态
正方
正方形
状态值
最大
矩阵
元素
篇文章
动态
更多
规划
不错
字符型
实用
最小
最长
位置
内容
取决于
含义
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
梦幻西游服务器配置
全国网络安全大会召开
如何把字典导入数据库mysql
赛群网络技术有限公司
北仑安卓软件开发设计
安国市委网络安全
部队板报网络安全
努娃厦门网络技术怎样
上海群控云控软件开发商
地税局网络安全技术检查
was8连接数据库
安全检查服务器初始化失败
吉林财务进销存软件开发
gridview 数据库
魔兽世界四川服务器主机
台湾人软件开发工资
vps搭建服务器搭建
流媒体服务器搭建工作
海南网络软件开发创新服务
怀柔区信息化网络技术服务平台
软件开发项目老总
全球主要科技互联网公司市值变化
凌源网络安全
韶关网络安全和信息化委员会
数据库连接池怎么改
dedecms数据库设置
春节网络安全科技馆
不用虚拟服务器可以做网站吗
玖富网络安全方式
怀柔区信息化网络技术服务平台