前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >leetcode刷题(103)——503. 下一个更大元素 II

leetcode刷题(103)——503. 下一个更大元素 II

作者头像
老马的编程之旅
发布2022-06-22 14:06:44
发布2022-06-22 14:06:44
18100
代码可运行
举报
文章被收录于专栏:深入理解Android深入理解Android
运行总次数:0
代码可运行

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

示例 1:

代码语言:javascript
代码运行次数:0
复制
输入: [1,2,1]
输出: [2,-1,2]
解释: 第一个 1 的下一个更大的数是 2;
数字 2 找不到下一个更大的数; 
第二个 1 的下一个最大的数需要循环搜索,结果也是 2。

注意: 输入数组的长度不会超过 10000。

比如输入一个数组[2,1,2,4,3],你返回数组[4,2,4,-1,4]。拥有了环形属性,最后一个元素 3 绕了一圈后找到了比自己大的元素 4。

一般是通过 % 运算符求模(余数),来获得环形特效:

代码语言:javascript
代码运行次数:0
复制
int[] arr = {1,2,3,4,5};
int n = arr.length, index = 0;
while (true) {
    print(arr[index % n]);
    index++;
}

这个问题肯定还是要用单调栈的解题模板,但难点在于,比如输入是[2,1,2,4,3],对于最后一个元素 3,如何找到元素 4 作为 Next Greater Number。

对于这种需求,常用套路就是将数组长度翻倍:

这样,元素 3 就可以找到元素 4 作为 Next Greater Number 了,而且其他的元素都可以被正确地计算。

代码语言:javascript
代码运行次数:0
复制
class Solution {
    public int[] nextGreaterElements(int[] nums) {
        Stack<Integer> stack = new Stack();
        int[] res = new int[nums.length];
        int length = nums.length;
        for(int i=2*nums.length-1;i>=0;i--){
            while(!stack.isEmpty()&&stack.peek()<=nums[i%length]){
                stack.pop();
            }
            if(!stack.isEmpty()){
                res[i%length]=stack.peek();
            }else{
                res[i%length]=-1;
            }
            stack.push(nums[i%length]);
        }
        return res;
    }
}

这里唯一需要注意就是stack.peek()<=nums[i%length]

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-02-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档