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
相关推荐
qq_380619162 分钟前
html怎么用deno运行_Deno如何作为本地服务器运行HTML文件
jvm·数据库·python
小鱼~~2 分钟前
进程和线程
python
wayz117 分钟前
Day 5:KNN算法与相似K线匹配
人工智能·算法·机器学习
断眉的派大星12 分钟前
pytorch中保存训练模型和加载训练模型的用法
人工智能·pytorch·python
C+++Python12 分钟前
如何学习Python的应用领域知识?
开发语言·python·学习
疯狂打码的少年15 分钟前
【Day12 Java转Python】Python工程的“骨架”——模块、包与__name__
java·开发语言·python
晨曦中的暮雨17 分钟前
Java集合类型主要有哪些?以及各自原理
数据结构·算法
ueotek22 分钟前
Ansys Zemax | 在 MATLAB 或 Python 中使用 ZOS-API 进行光线追迹的批次处理
python·matlab·ansys·zemax·光学软件
lixinnnn.29 分钟前
01BFS:Three States
算法
u01074754632 分钟前
mysql如何实现高可用集群架构_基于MHA环境搭建与部署
jvm·数据库·python