当前位置: 首页> 财经> 产业 > 代码随想录算法训练营第44天 | 第十章 单调栈part02

代码随想录算法训练营第44天 | 第十章 单调栈part02

时间:2025/8/23 12:43:49来源:https://blog.csdn.net/monoki/article/details/140684013 浏览次数:0次

文章目录

  • 今日记录
  • 42. 接雨水
  • 84.柱状图中最大的矩形
  • 总结


今日记录


42. 接雨水

Leetcode链接

class Solution {
public:int trap(vector<int>& height) {stack<int> st;st.push(0);int sum = 0;for (int i = 1; i < height.size(); i++) {if (height[i] < height[st.top()]) {st.push(i);} else if (height[i] == height[st.top()]) {st.pop();st.push(i);} else {while (!st.empty() && height[i] > height[st.top()]) {int mid = st.top();st.pop();if (!st.empty()) {int h = min(height[st.top()], height[i]) - height[mid];int w = i - st.top() - 1;sum += h * w;}}st.push(i);}}return sum;}
};

84.柱状图中最大的矩形

class Solution {
public:int largestRectangleArea(vector<int>& heights) {int result = 0;stack<int> st;st.push(0);heights.insert(heights.begin(), 0);heights.push_back(0);for (int i = 1; i < heights.size(); i++) {if (heights[i] > heights[st.top()]) {st.push(i);} else if (heights[i] == heights[st.top()]) {st.pop();st.push(i);} else {while (!st.empty() && heights[i] < heights[st.top()]) {int mid = st.top();st.pop();int left = st.top();int right = i;int w = right - left - 1;int h = heights[mid];result = max(result, w * h);}}st.push(i);}return result;}
};

总结

关键字:代码随想录算法训练营第44天 | 第十章 单调栈part02

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: