leetcode 221. 最大正方形

2023.11.8

        本题使用动态规划来做。dp[i][j]数组代表:以坐标[i][j]为左下角,只包含 1 的正方形的边长最大值 。

        遍历二维数组matrix,如果当前元素为0,则dp数组直接赋值0;如果当前元素为1,那么当前的边长最大值的递推公式为:dp[i][j] = Math.min(Math.min(dp[i-1][j],dp[i][j-1]),dp[i-1][j-1]) + 1;

即当前元素左边、左上、上边元素的最小值+1。

        此外,还需要考虑边界条件:如果当前元素的i或j为0的话,当前dp值就等于二维数组matrix对应位置的值,即:dp[i][j] = matrix[i][j],我选择直接初始化所有i或j为0的情况,也就是dp数组的第一行和第一列。

        java代码如下:

class Solution {public int maximalSquare(char[][] matrix) {int max_edge = 0;//全局变量维护最大边长的值int[][] dp = new int[matrix.length][matrix[0].length];//初始化dp数组的第一行和第一列for(int i=0; i<matrix.length; i++){dp[i][0] = matrix[i][0]-'0';max_edge = Math.max(max_edge,dp[i][0]);}for(int i=1; i<matrix[0].length; i++){dp[0][i] = matrix[0][i]-'0';max_edge = Math.max(max_edge,dp[0][i]);}//遍历赋值dp数组for(int i=1; i<matrix.length; i++){for(int j=1; j<matrix[0].length; j++){if(matrix[i][j] == '0'){dp[i][j] = 0;}else{dp[i][j] = Math.min(Math.min(dp[i-1][j],dp[i][j-1]),dp[i-1][j-1]) + 1;max_edge = Math.max(max_edge,dp[i][j]);}}}return max_edge*max_edge;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/164615.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java--实体javaBean

1.什么是实体类 1.就是一种特殊形式的类 2.这个类中的成员变量都要私有&#xff0c;并且要对外提供相应的getXXX&#xff0c;setXXX方法 3.类中必须要有一个公共的无参的构造器 2.实体类有啥应用场景 实体类只负责数据存取&#xff0c;而对数据的处理交给其他类来完成&…

IP地址冲突解决办法

在计算机网络中&#xff0c;每个设备都需要一个唯一的IP地址来与其他设备进行通信。然而&#xff0c;有时候会出现IP地址冲突的情况即多个设备使用了相同的IP地址。这种冲突会导致网络连接问题&#xff0c;因此需要及时解决。 IP地址查询&#xff1a;IP66_ip归属地在线查询_免费…

动手学Matplotlib画图,Matplotlib 是一个非常强大的 Python 画图工具。【Matplotlib学习笔记】

一、第一章 1.基本用法 import matplotlib.pyplot as plt import numpy as npx np.linspace(-1,1,50) y 2*x 1 plt.plot(x,y) plt.show()2.figure图像 import matplotlib.pyplot as plt import numpy as npx np.linspace(-1,1,50) y1 2*x 1 y2 x**2 plt.figure() plt…

【机器学习】Kmeans聚类算法

一、聚类简介 Clustering (聚类)是常见的unsupervised learning (无监督学习)方法&#xff0c;简单地说就是把相似的数据样本分到一组&#xff08;簇&#xff09;&#xff0c;聚类的过程&#xff0c;我们并不清楚某一类是什么&#xff08;通常无标签信息&#xff09;&#xff0…

Windows系统C++语言环境下通过SDK进行动作捕捉数据传输

NOKOV度量动作捕捉系统可以与市面上主流的操作系统和编程语言实现通信。可以在Windows系统C语言环境下通过SDK进行动作捕捉数据传输。 一、形影软件设置 1、实时模式和后处理模式都可以通过SDK传输数据。以后处理模式为例。将模式切换到后处理模式 2、加载一个刚体数据 3、打…

Nat. Med. | 基于遗传学原发部位未知癌症的分类和治疗反应预测

今天为大家介绍的是来自Alexander Gusev团队的一篇论文。原发部位未知癌症&#xff08;Cancer of unknown primary&#xff0c;CUP&#xff09;是一种无法追溯到其原发部位的癌症&#xff0c;占所有癌症的3-5&#xff05;。CUP缺乏已建立的靶向治疗方法&#xff0c;导致普遍预后…

SAPCRM销售订单集成创建

一、概述 越来越多的公司在数字化转型项目中不仅只上线SAP系统&#xff0c;而是将各模块外围系统同步上线&#xff0c;因此对于业务顾问来说&#xff0c;不只要写增强&报表的FS&#xff0c;还要提供外围系统集成的接口规范&#xff0c;以及集成方案&#xff0c;本文分享一…

【FastCAE源码阅读5】使用VTK实现鼠标拾取对象并高亮

鼠标拾取对象是很多软件的基本功能。FastCAE的拾取比较简单&#xff0c;是通过VTK实现的。 对几何而言&#xff0c;拾取类型切换在工具栏上&#xff0c;单击后再来单击视图区对象进行拾取&#xff0c;拾取后的对象会高亮显示。效果如下图&#xff1a; 一、拾取对象 拾取对象…

京东数据分析:2023年9月京东打印机行业品牌销售排行榜

鲸参谋监测的京东平台9月份打印机市场销售数据已出炉&#xff01; 鲸参谋数据显示&#xff0c;今年9月&#xff0c;京东平台打印机的销量为60万&#xff0c;环比增长约32%&#xff0c;同比下滑约25%&#xff1b;销售额为5亿&#xff0c;环比增长约35%&#xff0c;同比下滑约29%…

Spark 基础知识点

Spark 基础 本文来自 B站 黑马程序员 - Spark教程 &#xff1a;原地址 什么是Spark 什么是Spark 1.1 定义&#xff1a;Apache Spark是用于大规模数据&#xff08;large-scala data&#xff09;处理的统一&#xff08;unified&#xff09;分析引擎 Spark最早源于一篇论文 Re…

MySQL第八讲·如何进行数学计算、字符串处理和条件判断?

你好&#xff0c;我是安然无虞。 文章目录 如何进行数学计算、字符串处理和条件判断&#xff1f;数学函数字符串函数条件判断函数总结 如何进行数学计算、字符串处理和条件判断&#xff1f; MySQL 提供了很多功能强大&#xff0c;而且使用起来非常方便的函数&#xff0c;包括…

「掌握创意,释放想象」——Photoshop 2023,你的无限可能!

Adobe Photoshop 2023(PS2023) 来了,全世界数以百万计的设计师、摄影师和艺术家使用 Photoshop 将不可能变为可能。从海报到包装&#xff0c;从基本的横幅到漂亮的网站&#xff0c;从令人难忘的徽标到引人注目的图标&#xff0c;Photoshop 2023让创意世界不断前进。借助直观的工…