Leetcode221 最大正方形

最大正方形

    • [题解1 DP](#题解1 DP)
    • [题解2 暴力(参考)](#题解2 暴力(参考))

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

提示:

  • m == matrix.length, n == matrix[i].length
  • 1 <= m, n <= 300
  • matrix[i][j] 为 '0' 或 '1'

题解1 DP

cpp 复制代码
class Solution {
public:
    int maximalSquare(vector<vector<char>>& matrix) {
         int row = matrix.size(), col = matrix[0].size();
        // 定义:以 matrix[i][j] 为右下角元素的全为 1 正方形矩阵的最大边长为 dp[i][j]。
        vector<vector<int>> dp(row, vector<int>(col));
        // base case
        for(int i = 0; i < row; i++){
            dp[i][0] = matrix[i][0] - '0';
        }
        for(int i = 0; i < col; i ++){
            dp[0][i] = matrix[0][i] - '0';
        }
        // dp
        for(int i = 1; i < row; i++){
            for(int j = 1; j < col; j++){
                if(matrix[i][j] == '0') continue;
                // 木桶原理
                dp[i][j] = min(min(dp[i-1][j], dp[i][j-1]), dp[i-1][j-1]) + 1;
            }
        }
        int len = 0;
        for(int i = 0; i < row; i++){
            for(int j = 0; j < col; j++){
                len = max(len, dp[i][j]);
            }
        }
        return len*len;
    }
};

题解2 暴力(参考)

cpp 复制代码
class Solution {
public:
    int maximalSquare(vector<vector<char>>& matrix) {
        if (matrix.size() == 0 || matrix[0].size() == 0) {
            return 0;
        }
        int maxSide = 0;
        int rows = matrix.size(), columns = matrix[0].size();
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < columns; j++) {
                if (matrix[i][j] == '1') {
                    // 遇到一个 1 作为正方形的左上角
                    maxSide = max(maxSide, 1);
                    // 计算可能的最大正方形边长
                    int currentMaxSide = min(rows - i, columns - j);
                    for (int k = 1; k < currentMaxSide; k++) {
                        // 判断新增的一行一列是否均为 1
                        bool flag = true;
                        if (matrix[i + k][j + k] == '0') {
                            break;
                        }
                        for (int m = 0; m < k; m++) {
                        	// 行 || 列 
                            if (matrix[i + k][j + m] == '0' || matrix[i + m][j + k] == '0') {
                                flag = false;
                                break;
                            }
                        }
                        if (flag) {
                            maxSide = max(maxSide, k + 1);
                        } else {
                            break;
                        }
                    }
                }
            }
        }
        int maxSquare = maxSide * maxSide;
        return maxSquare;
    }
};
相关推荐
CoderCodingNo5 分钟前
【GESP】C++五级真题(数论, 贪心思想考点) luogu-B4070 [GESP202412 五级] 奇妙数字
开发语言·c++·算法
百***588411 分钟前
MATLAB高效算法实战技术文章大纲1
人工智能·算法·matlab
hans汉斯31 分钟前
【人工智能与机器人研究】自动移液设备多轴运动控制系统设计
算法·机器学习·3d·自然语言处理·机器人·硬件架构·汉斯出版社
guygg8840 分钟前
经典信道估计MATLAB实现(含LSMMSE算法)
深度学习·算法·matlab
foundbug9991 小时前
最小二乘支持向量机(LSSVM)回归的解析
算法·支持向量机·回归
程芯带你刷C语言简单算法题1 小时前
Day43~实现一个算法求一个数字的树根
c语言·开发语言·算法·c
柳鲲鹏2 小时前
关于#pragma pack(push, 8),DeepSeek回答错误
算法
settingsun12252 小时前
【AI-算法-01】ResNet (残差网络) & Skip Connections
人工智能·算法
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——两数之和
数据结构·算法·leetcode·力扣·结构与算法
福楠2 小时前
C++ STL | vector
开发语言·c++·算法