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
相关推荐
wang_yb2 分钟前
『Python底层原理』--Python整数为什么可以无限大
python·databook
yonuyeung3 分钟前
代码随想录算法【Day54】
java·数据结构·算法
敲上瘾9 分钟前
基础dp——动态规划
java·数据结构·c++·python·算法·线性回归·动态规划
阑梦清川24 分钟前
Jupyter里面的manim编程学习
python·jupyter·manim
西猫雷婶27 分钟前
python学智能算法(三)|模拟退火算法:深层分析
算法·机器学习·模拟退火算法
Dongwoo Jeong30 分钟前
类型系统下的语言分类与类型系统基础
java·笔记·python·lisp·fortran·type
张有志_1 小时前
STL容器终极解剖:C++ vector源码级实现指南 | 从内存分配到异常安全的全流程避坑
c语言·c++·算法·开源·visual studio
mvufi1 小时前
day58 第十一章:图论part08
数据结构·算法·图论
enyp801 小时前
*PyCharm 安装教程
ide·python·pycharm
williamzhou_20131 小时前
深搜专题2:组合问题
数据结构·算法