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;
    }
};
相关推荐
汀、人工智能17 小时前
[特殊字符] 第21课:最长有效括号
数据结构·算法·数据库架构·图论·bfs·最长有效括号
Boop_wu18 小时前
[Java 算法] 字符串
linux·运维·服务器·数据结构·算法·leetcode
故事和你9118 小时前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
Fcy64818 小时前
算法基础详解(三)前缀和与差分算法
算法·前缀和·差分
kvo7f2JTy19 小时前
基于机器学习算法的web入侵检测系统设计与实现
前端·算法·机器学习
List<String> error_P19 小时前
蓝桥杯最后几天冲刺:暴力大法(一)
算法·职场和发展·蓝桥杯
迈巴赫车主20 小时前
蓝桥杯3500阶乘求和java
java·开发语言·数据结构·职场和发展·蓝桥杯
流云鹤20 小时前
Codeforces Round 1090 (Div. 4)
c++·算法
wljy120 小时前
第十三届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(个人见解,已完结)
c语言·c++·算法·蓝桥杯·stl
高一要励志成为佬21 小时前
【数据结构】算法复杂度
数据结构