【力扣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] 为左下角,最大正方形的边长。

三、题解

cpp 复制代码
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;
    }
};
相关推荐
XiYang-DING1 小时前
jQuery
前端·javascript·jquery
明月_清风1 小时前
关于node 模块化的现状与未来
前端·node.js
呃呃本2 小时前
算法题(矩阵)
线性代数·算法·矩阵
老王以为2 小时前
从源码到架构:React useActionState 深度剖析
前端·javascript·react.js
前端超有趣2 小时前
详解JavaScript中encodeURIComponent和decodeURIComponent的使用(附实战场景)
前端·javascript
呃呃本2 小时前
算法题(普通数组、矩阵)
线性代数·算法·矩阵
计算机安禾2 小时前
【计算机网络】第11篇:链路状态路由协议——Dijkstra算法与OSPF的分区架构
计算机网络·算法·架构
珂朵莉MM2 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第二赛季优化题--遗传算法
人工智能·算法
gihigo19982 小时前
严格耦合波分析计算光栅衍射效率算法
算法