随想录一刷Day59——单调栈
admin
2024-01-31 11:25:18
0

文章目录

  • Day59_单调栈
    • 3. 下一个更大元素 II
    • 4. 接雨水

Day59_单调栈

3. 下一个更大元素 II

503. 下一个更大元素 II
思路:

方法一:
将数组复制一份拼接在尾部,然后对整个新数组利用单调栈求结果,最后将结果resize成原数组的大小

class Solution {
public:vector nextGreaterElements(vector& nums) {int nums_size = nums.size();nums.insert(nums.end(), nums.begin(), nums.end()); // 两个数组拼接在一起nums_size *= 2;vector result(nums_size, -1);stack stk;stk.push(0);for (int i = 1; i < nums_size; i++) {while (!stk.empty() && nums[i] > nums[stk.top()]) {result[stk.top()] = nums[i];stk.pop();}stk.push(i);}result.resize(nums_size / 2);return result;}
};

方法二:
优化一下,把插入元素和resize操作去掉,模拟数组复制两份的情况

class Solution {
public:vector nextGreaterElements(vector& nums) {int nums_size = nums.size();vector result(nums_size, -1);stack stk;stk.push(0);for (int j = 1; j < nums_size * 2; j++) {int i = j % nums_size;while (!stk.empty() && nums[i] > nums[stk.top()]) {result[stk.top()] = nums[i];stk.pop();}stk.push(i);}return result;}
};

4. 接雨水

42. 接雨水
思路1:双指针

遍历整个数组,找到每个柱子左右最高的柱子来判断该列可以接到多少水,累计所有柱子可以接到的水量。(首尾柱子不接水)

超时了(>人<;)
时间复杂度: O(n2)O(n^2)O(n2)
空间复杂度: O(1)O(1)O(1)

class Solution {
public:int trap(vector& height) {int size = height.size();int sum = 0;for (int i = 1; i < size - 1; i++) {int left_height = height[i];int right_height = height[i];for (int j = i - 1; j >= 0; j--) left_height = max(left_height, height[j]);for (int j = i + 1; j < size; j++) right_height = max(right_height, height[j]);sum += min(left_height, right_height) - height[i];}return sum;}
};

思路2:动态规划

双指针多次重复计算去找每一列的左右边界,使用数组将左右边界的值记录下来,可以省去重复的查找,这里用到了动态规划的思想,递推公式如下:

  • 左边界: leftheight[i] = max(leftheight[i], leftheight[i - 1]);
  • 右边界:rightheight[i] = max(rightheight[i], rightheight[i - 1];

时间复杂度: O(n)O(n)O(n)
空间复杂度: O(n)O(n)O(n)

class Solution {
public:int trap(vector& height) {int size = height.size();int sum = 0;vector left_h(size, 0);vector right_h(size, 0);left_h[0] = height[0];for (int i = 1; i < size; i++) left_h[i] = max(left_h[i - 1], height[i]);right_h[size - 1] = height[size - 1];for (int i = size - 2; i >= 0; i--) right_h[i] = max(right_h[i + 1], height[i]);for (int i = 1; i < size - 1; i++) sum += max(0, min(left_h[i], right_h[i]) - height[i]);return sum;}
};

思路3:单调栈

按行计算
计算获取单调栈,每次出现比栈顶元素大的元素时,说明出现了凹槽,该凹槽内的储水量是,高度是左右边界最小值与栈顶元素的差,宽度是右边界-左边界-1

时间复杂度: O(n)O(n)O(n)
空间复杂度: O(n)O(n)O(n)

class Solution {
public:int trap(vector& height) {int size = height.size();int sum = 0;stack stk;stk.push(0);for (int i = 1; i < size; i++) {while (!stk.empty() && height[i] > height[stk.top()]) {int mid = height[stk.top()];stk.pop();if (!stk.empty()) { // 有左右边界则可以储水int h = min(height[i], height[stk.top()]) - mid;int w = i - stk.top() - 1;sum += h * w;} // 只有单个边界不能存水}stk.push(i);}return sum;}
};

相关内容

热门资讯

汉口银行储蓄国债(电子式)手机... 2026年4月,经财政部和中国人民银行批准,汉口银行在湖北地方法人银行中首家上线储蓄国债(电子式)手...
AI引爆存储狂潮,全球芯片牛股... AI引爆超级牛市,储存芯片彻底涨疯了。 隔夜,美股芯片巨头强劲财报,再次引爆华尔街热情。 周二美股盘...
半导体板块领涨,消费电子ETF... 截至5月6日10点13分,上证指数涨1.11%,深证成指涨2.39%,创业板指涨3.34%。国家大基...
原创 俄... 在阅读本文前,麻烦各位先点下关注,方便之后我们共同讨论与分享。作为作者,我会不负所托,按时产出更高质...
俞浩:在中国,只有雷军、余承东... 一个做扫地机器人的,竟然要去做汽车和火箭?你会觉得追觅太飘了,不够脚踏实地吗? 今日追觅创始人兼CE...
从“五一”假期触摸中国经济发展... 原标题:活力奔涌动能足——从“五一”假期触摸中国经济发展脉动 立夏之际,中国大地生机勃发,处处跃动...
贺博生:5.6黄金暴涨原油暴跌... 投资市场永远有四个层次:保住本金,控制风险,赚取收益,长期稳定持续赢利。不要因为一天的输赢定结果,赚...
《异环》首日流水过亿,完美世界... ?2025年,完美世界交出了一份亮眼的成绩单。根据2025年年报,报告期内公司实现营业收入66.60...
白癜风医生刘云涛:盛夏养护不松... 盛夏是白癜风养护的关键期,也是巩固复色成果的黄金期。很多患者经过一段时间的治疗,白斑出现了复色迹象,...
SpaceX上市催化,卫星ET... 截至5月6日10点18分,上证指数涨1.20%,深证成指涨2.49%,创业板指涨3.49%。国家大基...
“排队3小时,打卡1分钟”,多... 来源:澎湃新闻 5月5日,首个叠加“春假”的“加长版五一”假期收官。当日,多个景区披露的数据显示,假...
科创板走强,多只科创50相关E... 科创板走强,海光信息涨20%,澜起科技、佰维存储涨超16%,寒武纪涨超11%。 受盘面影响,多只科创...
原创 巴... 2026巴菲特股东大会正式结束,巴菲特在60年来首次坐在台下担任特殊观众。这一次,巴菲特并没有发表太...
港股创新药概念股走弱,相关ET... 港股创新药概念股走弱,三生制药跌超3%,信达生物、石药集团跌超2%。 受盘面影响,港股创新药相关ET...
坎宁安23分哈登22+8+7 ... 【搜狐体育战报】北京时间5月6日NBA季后赛,主场作战的活塞以111-101击败骑士。杜伦11分12...
原创 潘... 现如今,能成功预测房地产市场趋势的人并不多,潘石屹就是其中之一。前些年,潘石屹就提出楼市的“黄金时代...
年度行情促“百亿券商”扩容,中... 上市券商全部“交卷”,去年和今年一季度业绩情况也随之揭晓。 2025年A股市场整体震荡上行,股权融资...
严选FOF强势崛起 银行重塑财... 近期,公募 FOF 市场迎来爆发式增长,多家银行加速布局严选 FOF、定制 FOF 产品。依托完善的...
“AI烧钱大战”依旧如火如荼!... 通财经APP获悉,美股市场七大科技巨头(即Magnificent 7)中的除英伟达之外的六大巨头已经...