代码随想录算法训练营第五十九天|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

相关推荐
DoraBigHead1 分钟前
小哆啦解题记:守护最小值的魔法栈
算法
JXL18609 分钟前
Leetcode-15. 三数之和
算法·leetcode·职场和发展
滋滋不吱吱1 小时前
枚举右,维护左
考研·算法·leetcode
快去睡觉~1 小时前
力扣146:LRU缓存
算法·leetcode·缓存
weixin_307779134 小时前
扇形区域拉普拉斯方程傅里叶解法2
算法
闪电麦坤9510 小时前
数据结构:字符串(Strings)
数据结构
宴之敖者、10 小时前
数组——初识数据结构
c语言·开发语言·数据结构·算法
青小莫10 小时前
c语言-数据结构-二叉树OJ
c语言·开发语言·数据结构·二叉树·力扣
典学长编程10 小时前
Java从入门到精通!第十一天(Java常见的数据结构)
java·开发语言·数据结构
胡斌附体10 小时前
oracle查询数据结构滤涉及的sql语句
数据结构·sql·oracle