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

相关推荐
Y1nhl11 分钟前
力扣hot100_普通数组_python版本
开发语言·python·算法·leetcode·职场和发展
m0_504135302 小时前
代码随想录算法训练营第六十一天 | floyd算法
算法
xin007hoyo6 小时前
算法笔记.染色法判断二分图
数据结构·笔记·算法
এ᭄画画的北北8 小时前
力扣-234.回文链表
算法·leetcode·链表
八股文领域大手子9 小时前
深入理解缓存淘汰策略:LRU 与 LFU 算法详解及 Java 实现
java·数据库·算法·缓存·mybatis·哈希算法
__lost10 小时前
C++ 解决一个简单的图论问题 —— 最小生成树(以 Prim 算法为例)
算法·图论·最小生成树·prim算法
wuqingshun31415911 小时前
蓝桥杯 11. 打印大X
数据结构·算法·职场和发展·蓝桥杯·深度优先
Blossom.11811 小时前
量子网络:构建未来通信的超高速“高速公路”
网络·opencv·算法·安全·机器学习·密码学·量子计算
A林玖11 小时前
【机器学习】朴素贝叶斯
人工智能·算法·机器学习
六边形战士DONK11 小时前
神经网络基础[损失函数,bp算法,梯度下降算法 ]
人工智能·神经网络·算法