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

相关推荐
万象.3 分钟前
redis数据结构list的基本指令
数据结构·redis·list
zephyr0510 分钟前
C++ STL unordered_set 与 unordered_map 完全指南
开发语言·数据结构·c++
wen__xvn14 分钟前
牛客周赛 Round 127
算法
大锦终16 分钟前
dfs解决FloodFill 算法
c++·算法·深度优先
橘颂TA29 分钟前
【剑斩OFFER】算法的暴力美学——LeetCode 200 题:岛屿数量
算法·leetcode·职场和发展
苦藤新鸡32 分钟前
14.合并区间(1,3)(2,5)=(1,5)
c++·算法·leetcode·动态规划
程序员-King.41 分钟前
day145—递归—二叉树的右视图(LeetCode-199)
算法·leetcode·二叉树·递归
漫随流水1 小时前
leetcode算法(112.路径总和)
数据结构·算法·leetcode·二叉树
过期的秋刀鱼!1 小时前
机器学习-带正则化的成本函数-
人工智能·python·深度学习·算法·机器学习·逻辑回归
ScilogyHunter1 小时前
前馈/反馈控制是什么
算法·控制