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

下一个更大元素(单调栈解)

文章目录

  • 单调栈 + 哈希表
    • 思路
    • 算法
    • 细节


单调栈 + 哈希表

496.下一个更大的元素

思路

我们可以先预处理 nums2,使查询 nums1中的每个元素在 nums2中对应位置的右边的第一个更大的元素值时不需要再遍历 nums2于是,我们将题目分解为两个子问题:
第 1个子问题:如何更高效地计算 nums2中每个元素右边的第一个更大的值;
第 2 个子问题:如何存储第 1 个子问题的结果。

算法

我们可以使用单调栈来解决第 1 个子问题。倒序遍历 nums2,并用单调栈中维护当前位置右边的更大的元素列表,从栈底到栈顶的元素是单调递减的。
具体地,每次我们移动到数组中一个新的位置 i,就将当前单调栈中所有小于 nums2[i] 的元素弹出单调栈,当前位置右边的第一个更大的元素即为栈顶元素,如果栈为空则说明当前位置右边没有更大的元素。随后我们将位置 i 的元素入栈。
因为题目规定了 nums2是没有重复元素的,所以我们可以使用哈希表来解决第 2 个子问题,将元素值与其右边第一个更大的元素值的对应关系存入哈希表。

细节

因为在这道题中我们只需要用到 nums2中元素的顺序而不需要用到下标,所以栈中直接存储 nums2中元素的值即可。

class Solution {public int[] nextGreaterElement(int[] nums1, int[] nums2) {Map<Integer, Integer> map = new HashMap<Integer, Integer>();Deque<Integer> stack = new ArrayDeque<Integer>();for (int i = nums2.length - 1; i >= 0; --i) {int num = nums2[i];while (!stack.isEmpty() && num >= stack.peek()) {stack.pop();}map.put(num, stack.isEmpty() ? -1 : stack.peek());stack.push(num);}int[] res = new int[nums1.length];for (int i = 0; i < nums1.length; ++i) {res[i] = map.get(nums1[i]);}return res;}
}

503.下一个更大的元素II
与上一题的区别是本题遍历的数组是循环数组且有重复项所以Map集合的key改为存储数组下标,将nums数组扩容为两倍进行遍历

class Solution {public int[] nextGreaterElements(int[] nums) {
Map<Integer,Integer>map=new  HashMap<>();
Deque<Integer>stack=new ArrayDeque<>();
int []nums2=new int[nums.length*2];
System.arraycopy(nums,0,nums2,0,nums.length);
System.arraycopy(nums,0,nums2,nums.length,nums.length);
for(int i=nums2.length-1;i>=0;i--){while(!stack.isEmpty()&&nums2[i]>=stack.peek()){
stack.pop();
}
map.put(i,stack.isEmpty() ? -1 : stack.peek());
stack.push(nums2[i]);
}
int []res=new int[nums.length];
for(int i=0;i<nums.length;i++){
res[i]=map.get(i);
}
return res;}
}

相关文章:

  • 【Pytest 测试报告完整模板:从异常处理到日志记录与截图】
  • Vue.js 3.x 必修课|008|计算属性:提高代码服用性和可维护性
  • *算法训练(leetcode)第三十九天 | 115. 不同的子序列、583. 两个字符串的删除操作、72. 编辑距离
  • Linux:账号和权限管理(一)
  • css 数字平铺布局
  • uni-app关于跨域问题(十七)
  • Go语言使用cobra开发第一个命令行程序
  • 【redis】springboot 用redis stream实现MQ消息队列 考虑异常ack重试场景
  • The C programming language (second edition,KR) exercise(CHAPTER 7)
  • 苹果手机清理软件:让你的iPhone保持最佳状态
  • JavaScript前端面试题——fetch
  • 上海冷链配送新篇章 华鼎冷链科技以卓越服务餐饮品牌
  • 技术汇总笔记7:switch 嵌套用法 和 改进 (条件分支相关内容)
  • Excel文件处理excel内容
  • FastAPI技巧
  • Codepen 每日精选(2018-3-25)
  • co模块的前端实现
  • ES6系统学习----从Apollo Client看解构赋值
  • Java多线程(4):使用线程池执行定时任务
  • markdown编辑器简评
  • mongo索引构建
  • OpenStack安装流程(juno版)- 添加网络服务(neutron)- controller节点
  • Python 基础起步 (十) 什么叫函数?
  • React-flux杂记
  • 阿里云前端周刊 - 第 26 期
  • 关于 Cirru Editor 存储格式
  • 回顾 Swift 多平台移植进度 #2
  • 嵌入式文件系统
  • 驱动程序原理
  • 全栈开发——Linux
  • 问题之ssh中Host key verification failed的解决
  • 我从编程教室毕业
  • 想使用 MongoDB ,你应该了解这8个方面!
  • 小程序、APP Store 需要的 SSL 证书是个什么东西?
  • 一个完整Java Web项目背后的密码
  • ​flutter 代码混淆
  • ​io --- 处理流的核心工具​
  • ​比特币大跌的 2 个原因
  • $.ajax()方法详解
  • (1)Android开发优化---------UI优化
  • (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
  • (附源码)spring boot火车票售卖系统 毕业设计 211004
  • (六)软件测试分工
  • (论文阅读22/100)Learning a Deep Compact Image Representation for Visual Tracking
  • (算法)求1到1亿间的质数或素数
  • (一)appium-desktop定位元素原理
  • ***原理与防范
  • *2 echo、printf、mkdir命令的应用
  • .FileZilla的使用和主动模式被动模式介绍
  • .NET Standard 的管理策略
  • .Net 基于MiniExcel的导入功能接口示例
  • .NET/C# 推荐一个我设计的缓存类型(适合缓存反射等耗性能的操作,附用法)
  • .NET上SQLite的连接
  • .net中我喜欢的两种验证码
  • @EnableAsync和@Async开始异步任务支持