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
相关推荐
嗯嗯=12 小时前
python学习篇
开发语言·python·学习
WoY202012 小时前
opencv-python在ubuntu系统中缺少依赖
python·opencv·ubuntu
大游小游之老游14 小时前
Python中如何实现一个程序运行时,调用另一文件中的函数
python
mantch14 小时前
个人 LLM 接口服务项目:一个简洁的 AI 入口
人工智能·python·llm
Swift社区14 小时前
LeetCode 465 最优账单平衡
算法·leetcode·职场和发展
聆风吟º14 小时前
【数据结构手札】空间复杂度详解:概念 | 习题
java·数据结构·算法
weixin_4450547215 小时前
力扣热题51
c++·python·算法·leetcode
地平线开发者15 小时前
linux 常见稳定性问题分析方法
算法·自动驾驶
朱朱没烦恼yeye15 小时前
java基础学习
java·python·学习
s砚山s15 小时前
代码随想录刷题——二叉树篇(九)
算法