您的位置:首页 > 职场人生

leetcode之maximal square

2016-03-29 11:11 363 查看
题目:

Given a 2D binary matrix filled with 0's and 1's, find the largest square containing all 1's and return its area.

For example, given the following matrix:
1 0 1 0 0
1 0 1 1 1
1 1 1 1 1
1 0 0 1 0

Return 4.

解答:

很明显的是一个dp,使用dp[i][j]表示以i,j为右下点的时候的最大的正方形的周长

dp[i][j] =min(min(dp[i - 1][j],dp[i][j - 1]),dp[i - 1][j - 1]);

class Solution {
public:
int getVal(int i,int j,vector<vector<int>> &dp)
{
if(i < 0 || i >= dp.size() || j < 0 || j >= dp[0].size())
return 0;
return dp[i][j];
}
int maximalSquare(vector<vector<char>>& matrix) {
int rows = matrix.size();
if(!rows)
return 0;
int cols = matrix[0].size();
if(!cols)
return 0;
vector<vector<int>> dp(rows,vector<int>(cols,0));
int res = 0;
for(int i = 0;i < rows;++i)
{
for(int j = 0;j < cols;++j)
{
if(matrix[i][j] == '0')
dp[i][j] = 0;
else
dp[i][j] = min(min(getVal(i - 1,j,dp),getVal(i, j - 1,dp)) , getVal(i - 1,j - 1,dp)) + 1;
if(dp[i][j] > res)
res = dp[i][j];
}
}
return res * res;
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  leetcode 算法 面试