C++ | Leetcode C++题解之第221题最大正方形

题目:

题解:

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();
        vector<vector<int>> dp(rows, vector<int>(columns));
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < columns; j++) {
                if (matrix[i][j] == '1') {
                    if (i == 0 || j == 0) {
                        dp[i][j] = 1;
                    } else {
                        dp[i][j] = min(min(dp[i - 1][j], dp[i][j - 1]), dp[i - 1][j - 1]) + 1;
                    }
                    maxSide = max(maxSide, dp[i][j]);
                }
            }
        }
        int maxSquare = maxSide * maxSide;
        return maxSquare;
    }
};
相关推荐
普通网友21 分钟前
C++中的组合模式
开发语言·c++·算法
江公望26 分钟前
Qt QByteArray类型,10分钟讲清楚
开发语言·c++·qt
2501_9411114631 分钟前
C++中的组合模式变体
开发语言·c++·算法
普通网友1 小时前
单元测试在C++项目中的实践
开发语言·c++·算法
沐怡旸2 小时前
【穿越Effective C++】条款22:将成员变量声明为private——封装的边界与设计的自由
c++
Swift社区3 小时前
LeetCode 427 - 建立四叉树
算法·leetcode·职场和发展
墨染点香4 小时前
LeetCode 刷题【160. 相交链表】
算法·leetcode·链表
少睡点觉4 小时前
LeetCode 238. 除自身以外数组的乘积 问题分析+解析
java·算法·leetcode
YoungHong19924 小时前
面试经典150题[066]:分隔链表(LeetCode 86)
leetcode·链表·面试
普通网友4 小时前
高性能TCP服务器设计
开发语言·c++·算法