当前位置: 首页 > article >正文

LeetCode:503.下一个更大元素II

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录

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]

  • 环状问题,可以假设后面还有一个一样的数组,这样就可以和以前一样操作
  • 如果真的复制一个数组,性能不好,可以假设有一个数组,然后取模即可
  • i < size之后,后面的元素不需要再入栈了,因为我们要求的是下一个最大元素即可,当i < size如果还继续入栈的话,会重复计算一些元素,没有必要,还影响性能,比如[4, 3, 6, 7,5],画图看一下即可
	public int[] nextGreaterElements(int[] nums) {
        int size = nums.length;
        int[] res = new int[size];
        Arrays.fill(res, -1);
        Deque<Integer> st = new ArrayDeque<>();

        for (int i = 0; i < size << 1; i++) {
            while (!st.isEmpty() && nums[i % size] > nums[st.peek()]) {
                res[st.pop() % size] = nums[i % size];
            }
            // st.push(i % size);
            if (i < size)
                st.push(i);
        }
        return res;
    }

http://www.kler.cn/a/537416.html

相关文章:

  • 【大数据技术】搭建完全分布式高可用大数据集群(Kafka)
  • 玩转Docker | 使用Docker部署httpd服务
  • 星闪开发入门级教程之安装编译器与小项目烧录
  • 使用Python创建、读取和修改Word文档
  • RabbitMQ深度探索:前置知识
  • 计算机毕业设计hadoop+spark+hive民宿推荐系统 酒店推荐系统 民宿价格预测 酒店价预测 机器学习 深度学习 Python爬虫 HDFS集群
  • 正则表达式进阶(二)——零宽断言详解:\b \B \K \z \A
  • 半导体行业跨网文件交换系统
  • declare和less
  • IDEA - 一个启动类多次启动方法
  • 解决ModuleNotFoundError: No module named ‘tomli‘
  • 使用Feign代替RestTemplet
  • 【图片合并转换PDF】如何将每个文件夹下的图片转化成PDF并合并成一个文件?下面基于C++的方式教你实现
  • 存储异常导致的Oracle重大生产故障
  • java练习(12)
  • 网络安全:挑战、技术与未来发展
  • 青少年编程与数学 02-008 Pyhon语言编程基础 26课题、常见框架
  • MariaDB *MaxScale*实现mysql8读写分离
  • LLM学习笔记1——本地部署Meta-Llama-3.2-1B大模型
  • 【网络工程师软考版】局域网与城域网
  • 网络HTTP详细讲解
  • C++ CRTP:奇异递归模板模式的原理与应用
  • 详解Swift中 Sendable AnyActor Actor GlobalActor MainActor Task、await、async
  • TDengine 中如何部署集群
  • 京东 rpc调用h5st
  • Python用langchain、OpenAI大语言模型LLM情感分析苹果股票新闻数据及提示工程优化应用...