Day58力扣打卡

打卡记录

下一个更大元素 IV(单调栈 x2)

链接

python 复制代码
class Solution:
    def secondGreaterElement(self, nums: List[int]) -> List[int]:
        ans = [-1] * len(nums)
        s = []
        t = []
        for i, x in enumerate(nums):
            while t and nums[t[-1]] < x:
                ans[t.pop()] = x  # t 栈顶的下下个更大元素是 x
            j = len(s) - 1
            while j >= 0 and nums[s[j]] < x:
                j -= 1  # s 栈顶的下一个更大元素是 x
            t += s[j + 1:]  # 把从 s 弹出的这一整段元素加到 t
            del s[j + 1:]  # 弹出一整段元素
            s.append(i)  # 当前元素(的下标)加到 s 栈顶
        return ans
相关推荐
暮冬-  Gentle°18 小时前
C++中的命令模式实战
开发语言·c++·算法
勾股导航18 小时前
大模型Skill
人工智能·python·机器学习
2501_9454235419 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
卷福同学20 小时前
【养虾日记】Openclaw操作浏览器自动化发文
人工智能·后端·算法
春日见20 小时前
如何入门端到端自动驾驶?
linux·人工智能·算法·机器学习·自动驾驶
FreakStudio20 小时前
保姆级 uPyPi 教程|从 0 到 1:MicroPython 驱动包一键安装 + 分享全攻略
python·嵌入式·电子diy
清水白石00820 小时前
Python 对象序列化深度解析:pickle、JSON 与自定义协议的取舍之道
开发语言·python·json
2401_8769075221 小时前
Python机器学习实践指南
开发语言·python·机器学习
图图的点云库21 小时前
高斯滤波实现算法
c++·算法·最小二乘法