随笔 - 455  文章 - 9  评论 - 17  阅读 - 18万

leetcode 85. Maximal Rectangle

Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing only 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 6.

我曹,还是单调栈。

记录下以当前行向上能得到的连续的1的个数(比如有sum[i]个),统计以这个sum[i]为最小值,向左,向右能扩展的最大距离。

复制代码
class Solution {
public:
    class node {
        public:
        int x, left, right;
    };
    int solve(int n, int m, vector<int>& sum) {
        vector<node> v;
        int ans = 0;
        for (int i = 0; i < m; ++i) {
            if (v.empty()) v.push_back({sum[i], i, i});
            else {
                node u = {sum[i], i, i};
                while(!v.empty() && sum[i] < v.back().x) {
                    node tmp = v.back(); v.pop_back();
                    if (!v.empty()) v.back().right = tmp.right;
                    u.left = tmp.left;
                    int y = (tmp.right - tmp.left + 1) * tmp.x;
                    if (y > ans) ans = y;
                }
                v.push_back(u);
            }
        }
        while (!v.empty()) {
            node tmp = v.back();
            v.pop_back();
            int y = (tmp.right - tmp.left + 1) * tmp.x;
            ans = max(ans, y);
            if (!v.empty()) v.back().right = tmp.right;
        }
        return ans;
    }
    int maximalRectangle(vector<vector<char>>& matrix) {
        int n = matrix.size();
        if (n == 0) return 0;
        int m = matrix[n-1].size();
        vector<int> sum(m);
        int ans = 0;
        for (int i = 0; i < m; ++i) sum[i] = (matrix[0][i] - '0');
        ans = solve(n, m, sum);
        for (int i = 1; i < n; ++i) {
            for (int j = 0; j < m; ++j) {
                if (matrix[i][j] == '1') sum[j]++;
                else sum[j] = 0;
            }
            ans = max(ans, solve(n, m, sum));
        }
        return ans;
    }
};
复制代码

 

posted on   Beserious  阅读(176)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
历史上的今天:
2015-08-25 Codeforces Round #Pi (Div. 2) C. Geometric Progression
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示