Day 52 || 739. 每日温度 、 496.下一个更大元素 I 、503.下一个更大元素II

739. 每日温度

题目链接: 力扣题目链接

**思路:**需要使用到单调栈,单调栈记录放入当前值所在数组的位置,只要当前数小于栈顶就放入,要是大于栈顶就弹出当记录的数组危及减去当前for循环的位置。

※要是求左侧或者右侧最大值栈就是从栈顶往栈底依次递增,相反左侧或者右侧最小值就是栈顶往栈底递减。

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

496.下一个更大元素 I

题目链接: 力扣题目链接

思路: 和"739. 每日温度"差不多,可以创建一个HashMap保存nums2的结果,便于nums1在其中快速找到结果。

496.下一个更大元素 I

题目链接: 力扣题目链接

**思路:**题目关键是如何将数组循环起来,可以for循环的长度乘以二,然后利用 i%nums.length来取余用来获得当前值,其他的就都相同,结果就是新的数组从零开始取原数组的长度的值。

复制代码
import java.util.Stack;
import java.util.Arrays;

class Solution {
    public int[] nextGreaterElements(int[] nums) {
        Stack<Integer> stack = new Stack<>();
        int[] res = new int[nums.length];
        Arrays.fill(res, -1);  // 初始化结果数组为 -1
        
        // 遍历 nums 数组两遍来模拟循环数组的效果
        for (int i = 0; i < nums.length * 2; i++) {
            int currentIndex = i % nums.length;  // 当前索引,使用模运算实现循环
            // 当栈不为空并且栈顶元素对应的值小于当前元素
            while (!stack.isEmpty() && nums[stack.peek()] < nums[currentIndex]) {
                int prevIndex = stack.pop();  // 弹出栈顶元素的索引
                res[prevIndex] = nums[currentIndex];  // 更新结果数组
            }
            // 只在第一次遍历时将当前索引压入栈
            if (i < nums.length) {
                stack.push(currentIndex);  // 将当前元素的索引压入栈
            }
        }
        
        return res;
    }
}

时间:2h

相关推荐
珊瑚里的鱼3 分钟前
【动态规划】三步问题
算法·动态规划
像素猎人5 分钟前
洛谷题B3882:求回文数【双指针】
算法·双指针
玖釉-5 分钟前
从有序链表合并看链表算法的指针设计:LeetCode 21「合并两个有序链表」深度解析
c++·windows·算法·leetcode·链表
碧海银沙音频科技研究院11 分钟前
音频算法移植与算法高效协同开发方法论
深度学习·算法·语音识别
计算机安禾13 分钟前
【算法分析与设计】第9篇:平摊分析与聚合核算技术
大数据·人工智能·算法
CQU_JIAKE20 分钟前
5.26【A】
算法
吃好睡好便好25 分钟前
提取矩阵某几行和某几列元素
人工智能·学习·线性代数·算法·matlab·矩阵
计算机安禾37 分钟前
【算法分析与设计】第11篇:图的表示与遍历算法:BFS与DFS的扩展性质
大数据·人工智能·算法
鱼子星_40 分钟前
【数据结构与算法】树(下):堆的实现与应用,二叉树的实现与基本操作
c语言·数据结构·算法
nwsuaf_huasir43 分钟前
RD图绘制-雷达回波模拟-距离多普勒图绘制
算法·matlab·语音识别