首页 > 编程语言 >#yyds干货盘点# LeetCode程序员面试金典:下一个更大元素 II

#yyds干货盘点# LeetCode程序员面试金典:下一个更大元素 II

时间:2023-12-01 22:01:21浏览次数:49  
标签:yyds nums int 金典 元素 ret II 更大 stack

题目

给定一个循环数组 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]

代码实现

class Solution {
    public int[] nextGreaterElements(int[] nums) {
        int n = nums.length;
        int[] ret = new int[n];
        Arrays.fill(ret, -1);
        Deque<Integer> stack = new LinkedList<Integer>();
        for (int i = 0; i < n * 2 - 1; i++) {
            while (!stack.isEmpty() && nums[stack.peek()] < nums[i % n]) {
                ret[stack.pop()] = nums[i % n];
            }
            stack.push(i % n);
        }
        return ret;
    }
}






标签:yyds,nums,int,金典,元素,ret,II,更大,stack
From: https://blog.51cto.com/u_15488507/8649293

相关文章