【随想录】Day57—第九章 动态规划part17

目录

  • [题目1: 每日温度](#题目1: 每日温度)
  • [题目2: 下一个更大元素 I](#题目2: 下一个更大元素 I)
    • [1- 思路](#1- 思路)
    • [2- 题解](#2- 题解)
      • [⭐ 下一个更大元素 I------题解思路](#⭐ 下一个更大元素 I——题解思路)

题目1: 每日温度


1- 思路

个人思路-暴力超时

  • 暴力解法,双层 for 循环 根据外层的 i 通过 j 来遍历数组。
    • 如果当前 i小于 j 的元素,则记录 j-i
java 复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        int[] res = new int[temperatures.length];

        // 双层 for
        for(int i = 0; i < temperatures.length;i++){
            for(int j = i ; j < temperatures.length;j++){
                if( temperatures[j] > temperatures[i]){
                    res[i] = j-i;
                    break;
                }else if(j == temperatures.length-1){
                    res[i] = 0;
                }
            }
        }
        return res;
    }
}

单调栈的意义
  • 单调栈 可以帮你找出,数组中右边元素 第一个比当前元素大的元素是什么、或者找左边第一个比当前元素大的元素。
本题中单调栈的作用
  • 本题中单调栈的作用是存放我们遍历过的元素
  • 之前遍历过哪些元素,和当前元素作对比

本题单调栈中存储的值

  • 如何存储,比较?
    • 直接存放下标
  • 递增栈还是递减栈?
    • 递增 or 递减 指的是单调栈从栈口 到 栈底 的位置
    • 递增:求得是右边第一个比当前元素大的元素
    • 递减:求得是右边第一个比当前元素小的元素

思路

  • 拿当前遍历到的元素 与 单调栈 的栈顶 元素做对比 ------> 根据三种情况进行判断,大于、小于、等于
  • 当前元素 大于 栈顶元素:nums[i] > nums[st.peek()]
    • 此时记录结果 res[st.peek()] = i - st.pop;
  • 当前元素 小于 栈顶元素:
    • 此时当前元素入栈,所以保证的是一个单调递增的栈
  • 当前元素 等于 栈顶元素:
    • 此时当前元素入栈

2- 题解

⭐ 每日温度 ------题解思路

java 复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        int[] res = new int[temperatures.length];
        // 定义单调栈
        Stack<Integer> st = new Stack();
        st.push(0);
        // 遍历 temperatures
        for(int i = 1 ; i < temperatures.length;i++){
            if(temperatures[i] <= temperatures[st.peek()]){
                st.push(i);
            }else{
                while(!st.isEmpty() && temperatures[i] > temperatures[st.peek()]){
                    res[st.peek()] = i - st.peek();
                    st.pop();
                }
                st.push(i);
            }
        }
        return res;
    }
}

题目2: 下一个更大元素 I


1- 思路

  • 1- 定义 nums1 大小的结果集
  • 2- 定义 Map 来寻找对应 nums2 中元素是否在 nums1 中
  • 3- 遍历维持单调队列

2- 题解

⭐ 下一个更大元素 I------题解思路

java 复制代码
class Solution {
    public int[] nextGreaterElement(int[] nums1, int[] nums2) {
        int[] res1 = new int[nums1.length];
        Arrays.fill(res1,-1);
        Stack<Integer> st = new Stack();
        st.push(0);

        // 针对 nums1 建立 Map
        Map<Integer,Integer> map = new HashMap<>();
        for(int i = 0 ; i < nums1.length;i++){
            map.put(nums1[i],i);
        }

        // 3- 维护 单调栈
        for(int i = 1 ; i < nums2.length;i++){
            if(nums2[i] <= nums2[st.peek()]){
                st.push(i);
            }else{
                while(!st.isEmpty() && nums2[i] > nums2[st.peek()]){
                    if(map.containsKey(nums2[st.peek()])){
                        int index = map.get(nums2[st.peek()]);
                        res1[index] = nums2[i];
                    }
                    st.pop();
                }
                st.push(i);
            }
        }
        return res1;
    }
}

相关推荐
fie888918 小时前
NSCT(非下采样轮廓波变换)的分解和重建程序
算法
晨晖219 小时前
单链表逆转,c语言
c语言·数据结构·算法
im_AMBER20 小时前
Leetcode 78 识别数组中的最大异常值 | 镜像对之间最小绝对距离
笔记·学习·算法·leetcode
鼾声鼾语21 小时前
matlab的ros2发布的消息,局域网内其他设备收不到情况吗?但是matlab可以订阅其他局域网的ros2发布的消息(问题总结)
开发语言·人工智能·深度学习·算法·matlab·isaaclab
LYFlied21 小时前
【每日算法】LeetCode 25. K 个一组翻转链表
算法·leetcode·链表
Swizard21 小时前
别再迷信“准确率”了!一文读懂 AI 图像分割的黄金标尺 —— Dice 系数
python·算法·训练
s090713621 小时前
紧凑型3D成像声纳实现路径
算法·3d·声呐·前视多波束
可爱的小小小狼21 小时前
算法:二叉树遍历
算法
d111111111d1 天前
在STM32函数指针是什么,怎么使用还有典型应用场景。
笔记·stm32·单片机·嵌入式硬件·学习·算法
AI科技星1 天前
质量定义方程常数k = 4π m_p的来源、推导与意义
服务器·数据结构·人工智能·科技·算法·机器学习·生活