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
相关推荐
小徐学编程-zZ1 小时前
量产测试数据
python·压力测试·数据库架构
QQ8057806511 小时前
django基于机器学习的电商评论情感分析系统设计实现
python·机器学习·django
X journey1 小时前
机器学习进阶(13):支持向量机SVM
算法·机器学习·支持向量机
wx09091 小时前
stata实现机器学习的环境配置
python·机器学习·stata
洛水水1 小时前
【力扣100题】30.二叉树的直径
算法·leetcode·职场和发展
gihigo19982 小时前
Bezier曲线曲面生成算法
算法
平行侠3 小时前
024多精度大整数 - 突破硬件精度限制的任意精度运算
数据结构·算法
nuowenyadelunwen3 小时前
CS 61A Lab 2 笔记:短路求值、高阶函数与 Lambda 表达式
python·函数式编程·cs61a·berkeley
IronMurphy3 小时前
【算法四十五】139. 单词拆分
算法
qq_422828624 小时前
android图形学之SurfaceControl和Surface的关系 五
android·开发语言·python