代码随想录训练营day58| 739. 每日温度 496.下一个更大元素 I

简介: 代码随想录训练营day58| 739. 每日温度 496.下一个更大元素 I

前言

代码随想录算法训练营day58


一、Leetcode 739. 每日温度

1.题目

给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。

示例 1:

输入: temperatures = [73,74,75,71,69,72,76,73] 输出: [1,1,4,2,1,1,0,0]

示例 2:

输入: temperatures = [30,40,50,60] 输出: [1,1,1,0]

示例 3:

输入: temperatures = [30,60,90] 输出: [1,1,0]

提示:

1. 1 <= temperatures.length <= 105
2. 30 <= temperatures[i] <= 100

来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/daily-temperatures

2.解题思路

方法一:暴力

对于温度列表中的每个元素 temperatures[i],需要找到最小的下标 j,使得 i < j 且 temperatures[i] < temperatures[j]。

由于温度范围在 [30, 100] 之内,因此可以维护一个数组 next 记录每个温度第一次出现的下标。数组 next 中的元素初始化为无穷大,在遍历温度列表的过程中更新 next 的值。

反向遍历温度列表。对于每个元素 temperatures[i],在数组 next 中找到从 temperatures[i] + 1 到 100 中每个温度第一次出现的下标,将其中的最小下标记为 warmerIndex,则 warmerIndex 为下一次温度比当天高的下标。如果 warmerIndex 不为无穷大,则 warmerIndex - i 即为下一次温度比当天高的等待天数,最后令 next[temperatures[i]] = i。

为什么上述做法可以保证正确呢?因为遍历温度列表的方向是反向,当遍历到元素 temperatures[i] 时,只有 temperatures[i] 后面的元素被访问过,即对于任意 t,当 next[t] 不为无穷大时,一定存在 j 使得 temperatures[j] == t 且 i < j。又由于遍历到温度列表中的每个元素时都会更新数组 next 中的对应温度的元素值,因此对于任意 t,当 next[t] 不为无穷大时,令 j = next[t],则 j 是满足 temperatures[j] == t 且 i < j 的最小下标。

3.代码实现

```java class Solution { public int[] dailyTemperatures(int[] temperatures) { int length = temperatures.length; int[] ans = new int[length]; int[] next = new int[101]; Arrays.fill(next, Integer.MAXVALUE); for (int i = length - 1; i >= 0; --i) { int warmerIndex = Integer.MAXVALUE; for (int t = temperatures[i] + 1; t <= 100; ++t) { if (next[t] < warmerIndex) { warmerIndex = next[t]; } } if (warmerIndex < Integer.MAX_VALUE) { ans[i] = warmerIndex - i; } next[temperatures[i]] = i; } return ans; } }
```

二、Leetcode 496.下一个更大元素 I

1.题目

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:

输入:nums1 = [4,1,2], nums2 = [1,3,4,2]. 输出:[-1,3,-1] 解释:nums1 中每个值的下一个更大元素如下所述: - 4 ,用加粗斜体标识,nums2 = [1,3,4,2]。不存在下一个更大元素,所以答案是 -1 。 - 1 ,用加粗斜体标识,nums2 = [1,3,4,2]。下一个更大元素是 3 。 - 2 ,用加粗斜体标识,nums2 = [1,3,4,2]。不存在下一个更大元素,所以答案是 -1 。

示例 2:

输入:nums1 = [2,4], nums2 = [1,2,3,4]. 输出:[3,-1] 解释:nums1 中每个值的下一个更大元素如下所述: - 2 ,用加粗斜体标识,nums2 = [1,2,3,4]。下一个更大元素是 3 。 - 4 ,用加粗斜体标识,nums2 = [1,2,3,4]。不存在下一个更大元素,所以答案是 -1 。

提示:

1. 1 <= nums1.length <= nums2.length <= 1000
2. 0 <= nums1[i], nums2[i] <= 104
3. nums1和nums2中所有整数 互不相同
4. nums1 中的所有整数同样出现在 nums2 中

来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/next-greater-element-i

2.解题思路

方法一:暴力

思路和算法

根据题意,我们发现 nums1nums1 是一个查询数组,逐个查询 nums2nums2 中元素右边的第一个更大的值。因此,我们可以暴力地逐个计算 nums1nums1 中的每个元素值 nums1[i]nums1[i] 在 nums2nums2 中对应位置的右边的第一个比 nums1[i]nums1[i] 大的元素值。具体地,我们使用如下方法:

1. 初始化与 nums1nums1 等长的查询数组 resres。
2. 
3. 遍历 nums1nums1 中的所有元素,不妨设当前遍历到元素为 nums1[i]nums1[i]:
4. 
5.     从前向后遍历 nums2nums2 中的元素,直至找到 nums2[j]=nums1[i]nums2[j]=nums1[i];
6. 
7.     从 j+1j+1 开始继续向后遍历,直至找到 nums2[k]>nums2[j]nums2[k]>nums2[j],其中 k≥j+1k≥j+1;
8. 
9.     如果找到了 nums2[k]nums2[k],则将 res[i]res[i] 置为 nums2[k]nums2[k],否则将 res[i]res[i] 置为 −1−1。
10. 
11. 查询数组 resres 即为最终结果。

3.代码实现

```java class Solution { public int[] nextGreaterElement(int[] nums1, int[] nums2) { int m = nums1.length, n = nums2.length; int[] res = new int[m]; for (int i = 0; i < m; ++i) { int j = 0; while (j < n && nums2[j] != nums1[i]) { ++j; } int k = j + 1; while (k < n && nums2[k] < nums2[j]) { ++k; } res[i] = k < n ? nums2[k] : -1; } return res; } }
```
相关文章
|
Android开发
eclipse控制台中文输出乱码解决方法
eclipse控制台中文输出乱码解决方法
546 0
|
JavaScript
Property “selectedItemIndex“ was accessed during render but is not defined on instance. 报错解决
Property “selectedItemIndex“ was accessed during render but is not defined on instance. 报错解决
1041 0
|
算法 安全 大数据
【C/C++ 随机函数行为】深入探索C++中的随机数:std::random_device与rand的行为分析(二)
【C/C++ 随机函数行为】深入探索C++中的随机数:std::random_device与rand的行为分析
461 0
|
存储 编解码 网络协议
Android平台GB28181执法记录仪硬件选型和国标技术实现探讨
前几年,我们在做Android平台GB28181设备接入模块的时候,第一个使用场景想到的就是用在公检法应急指挥等场景下的执法记录仪,本篇blog,我们主要围绕Android平台GB28181执法记录仪的硬件选型、设备接入、音视频流配置、流媒体传输、存储和管理、控制与控制中心等方面进行设计,探讨下Android平台GB28181设备接入模块在执法记录仪行业的应用。
417 1
Android平台GB28181执法记录仪硬件选型和国标技术实现探讨
|
数据可视化 JavaScript 开发工具
推荐7个有用的Jupyter扩展
推荐7个有用的Jupyter扩展
338 0
|
JavaScript 前端开发 开发者
使用jQuery Validate进行表单验证详解
使用jQuery Validate进行表单验证详解
|
存储 开发工具 git
解决“hint: the same ref. If you want to integrate the remote changes, usehint: ‘git pull‘ before pus”
解决“hint: the same ref. If you want to integrate the remote changes, usehint: ‘git pull‘ before pus”
441 3
|
Linux 数据处理
Linux中的mknod命令:深入解析与实用指南
**mknod命令详解:Linux下创建设备文件与FIFO的工具** mknod是Linux命令,用于创建设备文件(块设备、字符设备)和命名管道。设备文件连接用户空间与内核驱动,用于硬件交互;命名管道实现进程间通信。需root权限,语法:`mknod NAME TYPE MAJOR MINOR`,类型为&#39;b&#39;或&#39;c&#39;,主次设备号依硬件定。示例:创建块设备`/dev/sda`、字符设备`/dev/null`和FIFO`/tmp/myfifo`。使用时注意设备号正确性、避免名称冲突,并考虑使用udev自动管理。
|
运维 监控 算法
JDK 21中的分代ZGC:内存管理的革命性进步
本文深入探讨了JDK 21中引入的分代ZGC(Z Garbage Collector)的工作原理、特性及其对现代应用程序性能的影响。分代ZGC是一种基于分代收集的垃圾回收器,通过优化内存分配和回收过程,实现了更高的吞吐量和更低的延迟。本文将分析分代ZGC的设计哲学、技术细节以及在实际应用中的优势,并展示如何通过配置和优化分代ZGC来提升Java应用程序的性能。
1538 7

热门文章

最新文章