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
相关推荐
weixin_433179331 分钟前
Python - word jumble游戏
开发语言·python
小O的算法实验室29 分钟前
2024年IEEE TMC SCI1区TOP,面向无人机辅助 MEC 系统的轨迹规划与任务卸载的双蚁群算法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
Iridescent11211 小时前
Iridescent:Day48
python
BBB努力学习程序设计1 小时前
Python迭代器与生成器:优雅的惰性计算艺术
python
BBB努力学习程序设计1 小时前
Python描述符协议:属性访问的底层魔法
python
qq_317620311 小时前
第00章-Python学习大纲
python·python入门
Hello.Reader1 小时前
Table & SQL API 配置从“默认可用”到“针对场景调优”的一套方法论
数据库·python·sql
西部驯兽师1 小时前
NocoBase的开发技能
职场和发展
BoBoZz191 小时前
VTKWithNumpy使用 NumPy 数组来创建3D体渲染所需要的数据
python·vtk·图形渲染·图形处理
无才顽石1 小时前
什么是数学
算法·数理象