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
相关推荐
NAGNIP1 小时前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP2 小时前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮2 小时前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法
用户8356290780516 小时前
无需 Office:Python 批量转换 PPT 为图片
后端·python
爱理财的程序媛8 小时前
openclaw 盯盘实践
算法
markfeng88 小时前
Python+Django+H5+MySQL项目搭建
python·django
GinoWi9 小时前
Chapter 2 - Python中的变量和简单的数据类型
python
JordanHaidee9 小时前
Python 中 `if x:` 到底在判断什么?
后端·python
ServBay9 小时前
10分钟彻底终结冗长代码,Python f-string 让你重获编程自由
后端·python