

动态规划
- dp[i][j]是以(i,j)为右下角的只包含1的正方形的边长的最大值
- 针对每个位置(i,j):
- 元素为0,dp[i][j]=0
- 元素为1,dp[i][j]=min(dp[i-1][j],dp[i][j-1],dp[i-1][j-1])+1
- 元素为1的边界条件,i=0或j=0时dp[i][j]=1
class Solution {
public:
int maximalSquare(vector<vector<char>>& matrix) {
int m=matrix.size();
if(m==0) return 0;
int n=matrix[0].size();
vector<vector<int>> dp(m,vector<int>(n,0));
int d=0;
for(int i=0;i<m;i++){
for(int j=0;j<n;j++){
if(matrix[i][j]=='0'){
dp[i][j]=0;
}else{
if(i==0||j==0){
dp[i][j]=1;
}else{
dp[i][j]=min(dp[i-1][j-1],min(dp[i-1][j],dp[i][j-1]))+1;
}
d=max(d,dp[i][j]);
}
}
}
int area=d*d;
return area;
}
};
本文介绍了一个使用动态规划解决的问题,给定一个由0和1组成的二维矩阵,计算以每个位置为右下角且只包含1的正方形的最大边长。Solution类中的maximalSquare方法实现了这个算法并返回最大面积。
360

被折叠的 条评论
为什么被折叠?



