leetcode如何解决下一个更大元素问题
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,小编给大家分享一下leetcode如何解决下一个更大元素问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、题目内容给定
千家信息网最后更新 2025年12月03日leetcode如何解决下一个更大元素问题
小编给大家分享一下leetcode如何解决下一个更大元素问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
一、题目内容
给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素),输出每个元素的下一个更大元素。数字 x 的下一个更大的元素是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该循环地搜索它的下一个更大的数。如果不存在,则输出 -1。
示例 1:
输入: [1,2,1]
输出: [2,-1,2]
解释: 第一个 1 的下一个更大的数是 2;
数字 2 找不到下一个更大的数;
第二个 1 的下一个最大的数需要循环搜索,结果也是 2。
注意: 输入数组的长度不会超过 10000。
二、解题思路
将列表nums二次拼接,然后res存储每个数字下一个更大的元素,s存储每个元素的下标;
当前元素(s中栈顶对应的nums元素的下一个)大于s中栈顶对应的nums元素,res对应的s栈顶下标的下一个更大的元素为当前元素,s弹出栈顶下标;
s只存储nums长度的下标,而不是二次拼接之后的数组下标;
三、代码
class Solution: def nextGreaterElements(self, nums: list) -> list: res = [-1 for _ in range(len(nums))] s = [] two_nums = nums + nums for i in range(len(two_nums)): while s and nums[s[-1]] < two_nums[i]: res[s[-1]] = two_nums[i] # 当前元素(s中栈顶对应的nums元素的下一个)大于s中栈顶对应的nums元素 s.pop() # pop的是下标 # i大于nums的长度了就不往s里添加下标了 if i < len(nums): s.append(i) return resif __name__ == '__main__': s = Solution() nums = [1, 2, 1] ans = s.nextGreaterElements(nums) print(ans)
以上是"leetcode如何解决下一个更大元素问题"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
元素
下标
数组
数字
内容
篇文章
长度
存储
循环
输出
问题
搜索
输入
最大
不怎么
代码
大部分
思路
意味
更多
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
做软件开发对年龄有要求吗
南昌市米商网络技术有限公司
电力网络安全隐患排查总结
软件开发先进工作者
网络安全黑板报文字报题材
数据存储云服务器
云南网络安全厂商
网络安全个人观点
网络安全和舆情管理自查
学历查询为什么提示服务器异常
云南交通职业技术学院数据库
国家网络安全战略的原则有
总公司 网络安全管理办法
数据库中检查约束
随州网络安全手抄报
山西数据库防护箱行业
数据库数据提取到表单
软件开发为什么一直迷茫
数据库加缓存
网络安全宣传标语英语
怎么把sql的数据库文件导出来
如何用dsn连接数据库
万方数据库官网论文检索页查询
数据库技术优化策略
广东优匙网络技术有限公司
浪潮服务器网口聚合怎么做
vb如何判断数据库是否连通
sql后台数据库修改
网络安全宣传标语英语
江苏网络安全知识竞赛注册