LeetCode 503.下一个更大元素II

给定一个循环数组 nums ( nums[nums.length - 1] 的下一个元素是 nums[0] ),返回 nums 中每个元素的 下一个更大元素 。

数字 x 的 下一个更大的元素 是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该循环地搜索它的下一个更大的数。如果不存在,则输出 -1 。

示例 1:

输入: nums = [1,2,1]

输出: [2,-1,2]

解释: 第一个 1 的下一个更大的数是 2;

数字 2 找不到下一个更大的数;

第二个 1 的下一个最大的数需要循环搜索,结果也是 2。

示例 2:

输入: nums = [1,2,3,4,3]

输出: [2,3,4,-1,4]

提示:

1 <= nums.length <= 10 4 ^4 4

-10 9 ^9 9 <= nums[i] <= 10 9 ^9 9

使用单调栈,从后向前遍历两次即可,但第一次遍历时不填充结果数组:

cpp 复制代码
class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        stack<int> stk;
        vector<int> ans(nums.size(), -1);
        for (int i = nums.size() * 2 - 1; i >= 0; --i) {
            int idx = i % nums.size();

            while (!stk.empty() && nums[idx] >= stk.top()) {
                stk.pop();
            }

            if (!stk.empty() && i < nums.size()) {
                ans[i] = stk.top();
            }

            stk.push(nums[idx]);
        }

        return ans;
    }
};

如果nums的长度为n,则此算法时间复杂度为O(n),空间复杂度为O(n)。

相关推荐
_深海凉_1 小时前
LeetCode热题100-将有序数组转换为二叉搜索树
数据结构·算法·leetcode
KaMeidebaby1 小时前
卡梅德生物技术快报|单克隆抗体人源化 PEG 修饰质控方法体系构建与验证
服务器·前端·数据库·人工智能·算法·百度·新浪微博
不知名的老吴2 小时前
二叉树的遍历算法之先序遍历
算法
liu****2 小时前
第16届国赛蓝桥杯大赛C/C++大学B组
c语言·数据结构·c++·算法·蓝桥杯
SimpleLearingAI2 小时前
大模型推理框架总结解析
算法
Σίσυφος19002 小时前
正则化数据并校准数据
人工智能·算法·机器学习
HZ·湘怡2 小时前
基于动态数组的栈(顺序栈)01
数据结构·算法
Chen_harmony2 小时前
十八、C语言内存函数
c语言·算法
__Coffee__2 小时前
封装矩阵结构体
线性代数·算法·矩阵