代码随想录算法训练营第五十九天|503. 下一个更大元素 II、42. 接雨水

LeetCode 503. 下一个更大元素 II

题目链接:503. 下一个更大元素 II - 力扣(LeetCode)

该题在上一题:496. 下一个更大元素 I - 力扣(LeetCode)的基础上,进行循环遍历,因此我们就采用取模的方式来循环。

代码:

python 复制代码
#python
class Solution:
    def nextGreaterElements(self, nums: List[int]) -> List[int]:
        dp = [-1] * len(nums)
        stack = []
        for i in range(len(nums)*2):
            while(len(stack) != 0 and nums[i%len(nums)] > nums[stack[-1]]):  //取模
                    dp[stack[-1]] = nums[i%len(nums)]  //取模
                    stack.pop()
            stack.append(i%len(nums))
        return dp

LeetCode 42. 接雨水

题目链接:42. 接雨水 - 力扣(LeetCode)

之前好像考虑使用双指针尝试过该题,这次采用单调栈来实现。

代码:

python 复制代码
#python
class Solution:
    def trap(self, height: List[int]) -> int:
        stack = [0]
        result = 0
        for i in range(1, len(height)):
            while stack and height[i] > height[stack[-1]]:
                mid_height = stack.pop()
                if stack:
                    # 雨水高度是 min(凹槽左侧高度, 凹槽右侧高度) - 凹槽底部高度
                    h = min(height[stack[-1]], height[i]) - height[mid_height]
                    # 雨水宽度是 凹槽右侧的下标 - 凹槽左侧的下标 - 1
                    w = i - stack[-1] - 1
                    # 累计总雨水体积
                    result += h * w
            stack.append(i)
        return result

相关推荐
sali-tec6 分钟前
C# 基于halcon的视觉工作流-章54-N点标定
开发语言·图像处理·算法·计算机视觉·c#
娇娇yyyyyy15 分钟前
C++11新特性基础知识点汇总
开发语言·c++·算法
不知名。。。。。。。。27 分钟前
算法———栈
算法
烟花落o28 分钟前
指针深入第二弹--字符指针、数组指针、函数指针、函数指针数组、转移表的理解加运用
c语言·开发语言·笔记·vscode·算法
蓝色汪洋29 分钟前
数码和easy
算法
mit6.82444 分钟前
[VT-Refine] 强化学习工作流 | 分布式-近端策略优化(DPPO)
分布式·算法
小二·1 小时前
深入解析 Rust 并行迭代器:Rayon 库的原理与高性能实践
开发语言·算法·rust
国服第二切图仔1 小时前
Rust开发之错误处理与日志记录结合(log crate使用)
网络·算法·rust
ZHE|张恒2 小时前
LeetCode - 寻找两个正序数组的中位数
算法·leetcode
小龙报2 小时前
《算法通关指南算法千题篇(5)--- 1.最长递增,2.交换瓶子,3.翻硬币》
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio