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:
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;
}
};
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;
}
};
相关文章推荐
- 只有程序员看的懂的面试圣经|如何拿下编程面试
- 下一次技术面试时要问的 3 个重要问题
- 书评:《算法之美( Algorithms to Live By )》
- 动易2006序列号破解算法公布
- Ruby实现的矩阵连乘算法
- C#插入法排序算法实例分析
- PHP程序员面试 切忌急功近利(更需要注重以后的发展)
- 超大数据量存储常用数据库分表分库算法总结
- C#数据结构与算法揭秘二
- C#冒泡法排序算法实例分析
- 算法练习之从String.indexOf的模拟实现开始
- C#算法之关于大牛生小牛的问题
- C#实现的算24点游戏算法实例分析
- c语言实现的带通配符匹配算法
- 浅析STL中的常用算法
- 算法之排列算法与组合算法详解
- C++实现一维向量旋转算法
- Ruby实现的合并排序算法
- C#折半插入排序算法实现方法
- 基于C++实现的各种内部排序算法汇总