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
相关推荐
麦格芬2303 分钟前
LeetCode 763 划分字母区间
算法·leetcode·职场和发展
free-elcmacom8 分钟前
机器学习进阶<8>PCA主成分分析
人工智能·python·机器学习·pca
福尔摩斯张21 分钟前
C++核心特性精讲:从C语言痛点出发,掌握现代C++编程精髓(超详细)
java·linux·c语言·数据结构·c++·驱动开发·算法
liu****42 分钟前
Python 基础语法(二):程序流程控制
开发语言·python·python基础
面试鸭1 小时前
携程开启秋招补录
职场和发展·互联网
涛涛北京1 小时前
【强化学习实验】- 策略梯度算法
人工智能·算法
大连好光景1 小时前
Python打日志
运维·python·运维开发
栀秋6661 小时前
深入浅出链表操作:从Dummy节点到快慢指针的实战精要
前端·javascript·算法
syt_biancheng1 小时前
博客系统全流程测试总结
python·selenium·测试用例·压力测试·postman
Pyeako1 小时前
机器学习之KNN算法
人工智能·算法·机器学习