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; } };
原文地址:http://www.cnblogs.com/pk28/
与有肝胆人共事,从无字句处读书。
欢迎关注公众号:
欢迎关注公众号:

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .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