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
相关推荐
serve the people1 分钟前
tensorflow 深度解析 Sequential 模型的创建与层管理
人工智能·python·tensorflow
绿算技术5 分钟前
在稀缺时代,定义“性价比”新标准
大数据·数据结构·科技·算法·硬件架构
一起养小猫13 分钟前
《Java数据结构与算法》第四篇(二)二叉树的性质、定义与链式存储实现
java·数据结构·算法
乌萨奇也要立志学C++15 分钟前
【洛谷】贪心专题之哈夫曼编码 从原理到模板题解析
c++·算法
wfeqhfxz258878215 分钟前
条形码识别与定位:基于FCOS框架的多类型条码检测与识别技术详解
python
free-elcmacom15 分钟前
Python实战项目<3>赛制分数分析
开发语言·前端·python·数据分析
赵谨言16 分钟前
基于OpenCV的数字识别系统
大数据·开发语言·经验分享·python
飞天小蜈蚣1 小时前
http协议和django初识
python
路边草随风1 小时前
langchain agent动态变更系统prompt
人工智能·python·langchain·prompt
哥本哈士奇(aspnetx)8 小时前
Streamlit + LangChain 1.0 简单实现智能问答前后端
python·大模型