zoukankan      html  css  js  c++  java
  • LeetCode OJ: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.

    求出0,1矩阵中的最大矩形区域:

    DP问题,可以使用数组记下当前行位置之前的所有1的个数,然后用一个三重循环来找以(i,j)为右下角的矩形的最大的面积,比较得到最大值。这样做复杂度还是比较高的。但是胜在简单,代码如下所示:

     1 class Solution {
     2 public:
     3     int maximalRectangle(vector<vector<char>>& matrix) {
     4         if(matrix.size() == 0 || matrix[0].size() == 0)
     5             return 0;
     6         int szRow = matrix.size();
     7         int szCol = matrix[0].size();
     8         vector<vector<int>> dp(szRow, vector<int>(szCol, 0));//表示当前行前面含有的1的个数
     9         for(int i = 0; i < szRow; ++i){ //第一列的每一行的第一个元素
    10             dp[i][0] = matrix[i][0] == '1' ? 1 : 0;            
    11         }
    12         for(int i = 0; i < szRow; ++i){ //后面每列的每行的每个元素
    13             for(int j = 1; j < szCol; ++j){
    14                 dp[i][j] = matrix[i][j] == '1' ? dp[i][j-1]+1 : 0;
    15             }
    16         }
    17         int maxVal = 0;
    18         for(int i = 0; i < szRow; ++i){
    19             for(int j = 0; j < szCol; ++j){
    20                 int width = INT_MAX;
    21                 for(int k = i; k >=0 ; --k){
    22                     if(dp[k][j] == 0)
    23                         break;
    24                     width = min(width, dp[k][j]);//求出每次正方形的宽度
    25                     maxVal = max(maxVal, width * (i - k + 1));//宽度乘以高度
    26                 }
    27             }
    28         }
    29         return maxVal;
    30     }
    31 };

     先马一下别人写的方法,感觉写的挺好的,有时间在来写一下

  • 相关阅读:
    2020.12.11(读书笔记)
    python打包tkiner程序运行时任务栏图标
    使用py2exe打包exe
    word常用设置方法收集
    Helium初体验
    thkiner常用组件
    Java高并发16-LongAdder类源码解析(上)
    Java高并发15-AtomicLong等原子类源码解析
    Java高并发14-多线程下ThreadLcoalRandom源码解析以及对比
    如何做一个自动化感应垃圾桶
  • 原文地址:https://www.cnblogs.com/-wang-cheng/p/5027219.html
Copyright © 2011-2022 走看看