【随想录】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;
    }
}

相关推荐
计算机小白一个6 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^7 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
大数据追光猿9 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!9 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉9 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生9 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴9 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing9 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode
qy发大财9 小时前
加油站(力扣134)
算法·leetcode·职场和发展
王老师青少年编程9 小时前
【GESP C++八级考试考点详细解读】
数据结构·c++·算法·gesp·csp·信奥赛