代码随想录冲冲冲 Day47 单调栈Part1

739. 每日温度

初步了解单调栈,根本思想就是如果求的是一个元素右边或左边第一个最大的元素 那么就是递增栈,如果是最小的就是递减栈

首先先放入一个0代表 第一个元素的index

之后开始for loop

当后面的值小于等于这个top时 就要先把index放入st中,说明之前放入的还没找到

第一个最大的,刚刚放入的这些也是要找的

当出现一个值大于top时

result的st.top()也就是之间放入的值的位置就等于差值(题目需要的)

比较完后把比较过的pop走

但是没有办法保证是不是另一个也可以pop所以这里while loop的条件不仅是大小

还要确保是不是为空,如果不为空并且持续满足 就会一直运行

直到不满足条件时,这时候就是st为空了或者是当前值比st里面放着的值更小了

更小了就得先给这个更小的找了 所以st中把更小的这个的index值放入

496. 下一个更大元素 I

这道和上一道基本一样,不一样的是题目中要求放另一个nums的元素到第一个的位置上

所以需要一个map去记录第一个nums每个元素的index

当出现满足while条件时,要判断一下nums2的这个元素是不是在第一个中

如果不在根本就放不进去,如果在的话根据umap就可以知道改把这个元素放在什么地方

503. 下一个更大元素 II

这道题是一个循环情况我们选择的是forloop i< nums.size()*2

这样像是nums的最后一个元素 就可以得到答案

但是这里的关键步骤还有取%,在取%后,当i 大于了nums.size()后,会自然回到

一开始的地方,就相当于又重新开始比较了

相关推荐
刘马想放假2 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠3 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦10 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠11 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾11 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82111 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q11 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒11 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记11 天前
单项不带头不循环链表
数据结构·链表
小糯米60111 天前
JS 数组
数据结构·算法·排序算法