leetcode如何解决下一个更大元素问题
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,小编给大家分享一下leetcode如何解决下一个更大元素问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、题目内容给定
千家信息网最后更新 2025年01月31日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安全错误
数据库的锁怎样保障安全
组织学生网络安全校园起
数据库完整性定义
喵喵宝可梦服务器下载安装
网络安全学好难吗
网络安全学校宣传语
本地服务器防冲突
苹果手机数据库需要什么属性
成立中央网络安全和信化领导小组
面试常考软件开发流程
网络安全怎样理解
湖南红色文化馆软件开发系统
软件开发数据库搭建
亳州求职招聘软件开发哪家好
完美平台链接服务器
短信服务器不可用怎么回事
小程序发布是上传到服务器吗
为什么加强网络安全意识
网络安全心理剧
交通部网络安全管理办法
网络安全法 行动方案
数据库下载安装
软件开发有哪几个阶段 测试
ea服务器下载
河南网络技术服务概况
网络安全法解释有几部
易飞用什么软件开发
面试常考软件开发流程
瑞丽家居设计软件开发
测试人员为什么要学数据库
年度网络安全工作目标