Maximal Rectangle

题目

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

思路一:O(N4)

遍历,不断更新最大值。

class Solution {
public:
    int maximalRectangle(vector<vector<char> > &matrix) {
        // Start typing your C/C++ solution below
        // DO NOT write int main() function
        if (matrix.empty() || matrix[0].empty()) 
            return 0;
        int max = 0;
        for(int row = 0; row < matrix.size(); row++)
            for(int col = 0; col < matrix[0].size(); col++){
                int area = getArea(matrix, row, col);
                if (max < area) max = area;
            }
        return max;
    }
    int getArea(vector<vector<char> > &matrix, int const cornerRow, int const cornerCol){
        int maxArea = 0;
        int maxX = matrix[0].size();
        for(int row = cornerRow; row < matrix.size(); ++row){
            if (matrix[row][cornerCol] == '0') break;
            for(int x = cornerCol; x < maxX; ++x){
                if (matrix[row][x] == '0'){
                    maxX = x;
                    break;
                }
            }
            int area = (maxX-cornerCol) * (row-cornerRow+1);
            if (maxArea <area) maxArea = area;
        }
        return maxArea;        
    }
};

思路二:O(N3)

用f[i][j]来记录i行以j列为结尾,往前连续的1的个数。然后再一个O(n^3)的循环来找以(i, j)为右下角的矩形最大的1的面积。

上述矩阵将产生:

0 1 2 3 0

0 1 2 3 4

0 0 1 0 1

 

class Solution {
 public:
     int maximalRectangle(vector<vector<char> > &matrix) {
         // Start typing your C/C++ solution below
         // DO NOT write int main() function
         if(matrix.size()==0 || matrix[0].size()==0)
             return 0;
         vector<vector<int> > f(matrix.size()+1, vector<int>(matrix[0].size()+1,0));
         for(int i=0; i<matrix.size(); i++)
             f[i][0] = matrix[i][0]=='1'?1:0;
         // Create the row-lines with number of 1s 
         for(int i=0; i<matrix.size(); i++)
             for(int j=1; j<matrix[i].size(); j++)
                 f[i][j] = matrix[i][j]=='1'?f[i][j-1]+1:0;
         // Make (i,j) as the right-bottom corner, and find the max-rows-cols        
         int result = 0;         
         for(int i=0; i<matrix.size(); i++)
             for(int j=0; j<matrix[i].size(); j++)
             {
                 int k = i;
                 int width = INT_MAX;             
                 while(k >= 0)
                 {
                     if(f[k][j] == 0)  break;                 
                     width = min(width,f[k][j]);
                     result = max(result, width*(i-k+1));   
                     k--;                   
                 }
             }             
         return result;
     }
 };

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值