当前位置: 首页 > news >正文

【力扣hot100】 221. 最大正方形

一、题目

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

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

输入:matrix = [["0","1"],["1","0"]] 输出:1 示例 3: 输入:matrix = [["0"]] 输出:0 提示: m == matrix.length n == matrix[i].length 1 <= m, n <= 300 matrix[i][j] 为 '0' 或 '1'

二、思路

看着感觉是动态规划,但一时半会感觉想不出来,直接问gpt了。

给出的思路也很简单,就是反复在(左,上,左上)取小并加一,验证正方形的最大边即可。本质就是以 dp[i][j] 为左下角,最大正方形的边长

三、题解

class Solution { public: int maximalSquare(vector<vector<char>>& matrix) { vector<vector<int>> dp(matrix.size(),vector<int>(matrix[0].size(),0)); int maxValue=0; for(int i=0;i<matrix.size();i++){ for(int j=0;j<matrix[0].size();j++){ if(matrix[i][j]=='1'){ if(i==0||j==0){ dp[i][j]=1; } else{ dp[i][j]=min(dp[i-1][j],min(dp[i][j-1],dp[i-1][j-1]))+1; } maxValue=max(dp[i][j],maxValue); } } } return maxValue*maxValue; } };
http://www.jsqmd.com/news/757126/

相关文章:

  • Honey Select 2终极增强方案:如何一键解锁完整游戏体验
  • HCIP园区网
  • 在Node.js后端服务中集成Taotoken多模型API提升开发效率
  • ResNeXt的‘分组卷积’到底强在哪?用PyTorch代码和torchsummary带你算清参数量和计算量
  • 黑苹果启动盘修复完整指南:解决EFI引导问题的实用方法
  • 如何快速修复ComfyUI-ControlNet-Aux中Depth Anything节点报错问题
  • 如何彻底解决微信聊天记录丢失问题:WeChatMsg数据自主权完全指南
  • 内蒙古 CPPM 和 SCMP 报考新选择(众智商学院)联系方式 - 众智商学院课程中心
  • 从下载到验证:手把手教你为Cadence Virtuoso配置TSMC 1P6M工艺库(附display.drf文件修复)
  • Datasette ChatGPT插件:用自然语言查询SQLite数据库的实践指南
  • 离线策略蒸馏与强化学习在推荐系统中的对比实践
  • ThinkRAG:基于LlamaIndex与Streamlit的本地化中文知识库问答系统实践
  • 马斯克起诉OpenAI:一家非营利机构的商业化转型,算违法吗?
  • 从B站教程到实战避坑:3ds Max 2018模型缩放100倍导入UE5的完整流程(附素材)
  • 第5节:部署架构、性能预判与数据设计
  • 从51单片机到STM32:聊聊我项目里用过的几种软件架构(附代码避坑)
  • 上海市 CPPM 和 SCMP 报考新选择(众智商学院)联系方式 - 众智商学院课程中心
  • Tiled地图编辑器终极指南:从零开始创建专业2D游戏地图
  • wiliwili:跨平台B站客户端终极使用指南
  • TegraRcmGUI:让Switch破解注入从复杂命令到轻松点击的转变之旅
  • 3步轻松安装Windows 11:MediaCreationTool.bat帮你绕过所有硬件限制
  • Python 开发者如何利用 Taotoken 的 OpenAI 兼容协议快速调用多模型
  • 基于Node.js的自动化签到机器人:原理、部署与脚本开发实战
  • 2026年3月草坪灯源头厂家推荐,特色景观灯/中山景观灯/LED圆球壁灯/园区景观灯/城市道路灯,草坪灯厂家选哪家 - 品牌推荐师
  • 开源项目如何重构直播数据价值体系:DouyinLiveRecorder的技术架构与数据捕获实践
  • HsMod:炉石传说玩家的游戏效率与个性化优化插件
  • 保姆级教程:在Firefly RK3568开发板上为Android11添加4G模块(广和通NL668)
  • Qt 信号与槽 [ 2 ]
  • Obsidian PDF++:打造原生PDF标注与知识管理的终极解决方案
  • 告别云端依赖:用TensorFlow Lite在Android手机上跑通你的第一个AI模型(附完整代码)