代码随想录算法训练营第58天 | 739、496

news/2024/11/20 4:17:50/

739. 每日温度

题目描述

给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。
示例1:
输入: t e m p e r a t u r e s = [ 73 , 74 , 75 , 71 , 69 , 72 , 76 , 73 ] temperatures = [73,74,75,71,69,72,76,73] temperatures=[73,74,75,71,69,72,76,73]
输出: [ 1 , 1 , 4 , 2 , 1 , 1 , 0 , 0 ] [1,1,4,2,1,1,0,0] [1,1,4,2,1,1,0,0]
示例2:
输入: t e m p e r a t u r e s = [ 30 , 40 , 50 , 60 ] temperatures = [30,40,50,60] temperatures=[30,40,50,60]
输出: [ 1 , 1 , 1 , 0 ] [1,1,1,0] [1,1,1,0]
示例3:
输入: t e m p e r a t u r e s = [ 30 , 60 , 90 ] temperatures = [30,60,90] temperatures=[30,60,90]
输出: [ 1 , 1 , 0 ] [1,1,0] [1,1,0]

思路

单调栈的应用典中典
主要需要在意的是三个判断条件
1)当前遍历的元素小于栈顶元素
2)当前遍历的元素等于栈顶元素
3)当前遍历的元素大于栈顶元素
一般情况下2)会与1)或3)相结合一同判断

解法1

class Solution {public int[] dailyTemperatures(int[] temperatures) {int lens = temperatures.length;int[] res = new int[lens];Stack<Integer> stk = new Stack<>();stk.push(0);for(int i = 1;i < lens;i++){if(temperatures[i] <= temperatures[stk.peek()]){stk.push(i);}else{while(!stk.isEmpty() && temperatures[i] > temperatures[stk.peek()]){res[stk.peek()] = i - stk.peek();stk.pop();}stk.push(i);}}return res;}
}

解法2

class Solution {public int[] dailyTemperatures(int[] temperatures) {int lens = temperatures.length;int[] res = new int[lens];Stack<Integer> stk = new Stack<>();for(int i = 0;i<lens;i++){while(!stk.isEmpty() && temperatures[i] > temperatures[stk.peek()]){res[stk.peek()] = i - stk.peek();stk.pop();}stk.push(i);}return res;}
}

总结

单调栈还是第一次学,从本题上看还是比较好识别的。好好看,好好学。

496. 下一个更大元素Ⅰ

题目描述

nums1 中数字 x 的 下一个更大元素 是指 x 在 nums2 中对应位置 右侧 的 第一个 比 x 大的元素。
给你两个 没有重复元素 的数组 nums1 和 nums2 ,下标从 0 开始计数,其中nums1 是 nums2 的子集。
对于每个 0 <= i < nums1.length ,找出满足 nums1[i] == nums2[j] 的下标 j ,并且在 nums2 确定 nums2[j] 的 下一个更大元素 。如果不存在下一个更大元素,那么本次查询的答案是 -1 。
返回一个长度为 nums1.length 的数组 ans 作为答案,满足 ans[i] 是如上所述的 下一个更大元素 。
示例1:
输入: n u m s 1 = [ 4 , 1 , 2 ] , n u m s 2 = [ 1 , 3 , 4 , 2 ] nums1 = [4,1,2], nums2 = [1,3,4,2] nums1=[4,1,2],nums2=[1,3,4,2]
输出: [ − 1 , 3 , − 1 ] [-1,3,-1] [1,3,1]
示例2:
输入: n u m s 1 = [ 2 , 4 ] , n u m s 2 = [ 1 , 2 , 3 , 4 ] nums1 = [2,4], nums2 = [1,2,3,4] nums1=[2,4],nums2=[1,2,3,4]
输出: [ 3 , − 1 ] [3,-1] [3,1]

思路

本题与上一题类似,但有一个需要注意的点是,要判断nums2此时的元素是否在nums1中出现过,只有出现过才能记录,否则要跳过。

解法1

class Solution {public int[] nextGreaterElement(int[] nums1, int[] nums2) {Stack<Integer> tmp = new Stack<>();int[] res = new int[nums1.length];Arrays.fill(res,-1);HashMap<Integer,Integer> map = new HashMap<>();for(int i = 0;i<nums1.length;i++){map.put(nums1[i],i);}tmp.add(0);for(int i = 1;i<nums2.length;i++){if(nums2[i] <= nums2[tmp.peek()]){tmp.add(i);}else{while(!tmp.isEmpty() && nums2[tmp.peek()] < nums2[i]){if(map.containsKey(nums2[tmp.peek()])){Integer index = map.get(nums2[tmp.peek()]);res[index] = nums2[i];}tmp.pop();}tmp.add(i);}}return res;}
}

解法2

class Solution {public int[] nextGreaterElement(int[] nums1, int[] nums2) {HashMap<Integer,Integer> map = new HashMap<>();for(int i = 0;i<nums1.length;i++){map.put(nums1[i],i);}int[] res = new int[nums1.length];Stack<Integer> stk = new Stack<>();Arrays.fill(res,-1);for(int i = 0;i<nums2.length;i++){while(!stk.isEmpty() && nums2[stk.peek()] < nums2[i]){int pre = nums2[stk.pop()];if(map.containsKey(pre)){res[map.get(pre)] = nums2[i];}}stk.push(i);}return res;}
}

总结

相当于上一题的升级版,也是对单调栈应用的考察,好好看,好好学。


http://www.ppmy.cn/news/140727.html

相关文章

紫外线消毒器:不锈钢紫外线消毒器

紫外线消毒器又称为紫外线杀菌设备&#xff0c;紫外线杀菌器&#xff0c;主要是紫外线是物质运行的一种特殊形式&#xff0c;是一种不连接的粒子流。每一粒波长253.7nm的紫外线光子具有4.9eV的能量&#xff0c;当细菌、病毒吸收超过3600~65000uW/c㎡剂量时&#xff0c;对细菌、…

中国消毒柜行业市场深度调研及投资策略预测报告

智研瞻产业研究院专注于中国产业经济情报及研究&#xff0c;目前主要提供的产品和服务包括传统及新兴行业研究、商业计划书、可行性研究、市场调研、专题报告、定制报告等。涵盖文化体育、物流旅游、健康养老、生物医药、能源化工、装备制造、汽车电子、农林牧渔等领域&#xf…

紫外线消毒器设计和安装说明

近年来&#xff0c;随着对紫外线消毒优势和紫外线消毒器价格优势的认知&#xff0c;越来越多的紫外线消毒设备用于生活饮用水消毒&#xff0c;生活饮用水紫外线消毒设备多采用过流管道式构造形式。管道式紫外线消毒器设计和安装说明有以下几点&#xff1a; 1、紫外线消毒器工作…

微电解自洁消毒器应用介绍与水箱自洁式消毒器的区别

微电解自洁消毒器应用介绍与水箱自洁式消毒器的区别有哪些呢&#xff1f; 我们知道水箱自洁式消毒器分为内置式水箱消毒器与外置式水箱消毒器他们之间的区别有哪些呢 带着疑问我们来看下面的介绍 微电解自洁消毒器概述 人们在生活中都有可能&#xff08;居住、办公、就…

【方太】顺利通过CMMI3认证

近日&#xff0c;在擎标顾问团的的咨询辅导下&#xff0c;杭州方太智能科技有限公司顺利通过CMMI&#xff08;即软件能力成熟度模型集成&#xff09;成熟度评估&#xff0c;取得CMMI V2.0三级资质。标志着企业已经具备的软件成熟度与项目管理能力&#xff0c;涵盖软件研发能力、…

地址消毒

原文在 AddressSanitizer: A Fast Address Sanity Checker 还有一些讨论在&#xff1a;http://stackoverflow.com/questions/11806469/clang-with-faddress-sanitizer-on-windows 摘要 内存访问问题&#xff0c;如buffer越界访问&#xff0c;使用已经释放的内存等&#xff0c;…

奶瓶消毒柜语音提示芯片,音效ic选型

准爸爸准妈妈们都会在宝宝出生前把奶瓶、奶嘴等婴儿用品备好。而除了给宝宝选购的奶瓶奶嘴要保证安全和质量&#xff0c;为了减少细菌对宝宝身体的伤害&#xff0c;这时候大部分家长就会选择奶瓶消毒柜定期给奶瓶进行消毒。 奶瓶消毒柜一般有四个操作按钮&#xff1a;电源轻触即…

方太老板布局集成灶行业?未来会对集成灶行业产生什么影响?

在消费升级驱动下&#xff0c;消费者多元化烹饪需求日益增加&#xff0c;因此集成灶应运而生。集成灶将油烟机、燃气灶、蒸烤箱等多种功能整合于一机&#xff0c;烹饪功能多样&#xff0c;吸油烟能力强&#xff0c;满足了国人对厨房日益增长的新需求&#xff0c;成为增速较快的…