当前位置: 首页 > ds >正文

力扣 hot100 Day67

739. 每日温度

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

//抄的
class Solution {
public:vector<int> dailyTemperatures(vector<int>& temperatures) {int n = temperatures.size();vector<int> answer(n, 0);stack<int> stk; // 存储的是天数索引for (int i = 0; i < n; ++i) {// 当栈不为空且当前温度大于栈顶那天的温度时while (!stk.empty() && temperatures[i] > temperatures[stk.top()]) {int prev_day = stk.top();stk.pop();answer[prev_day] = i - prev_day; // 计算天数差}stk.push(i); // 压入当前天数}return answer;}
};

stk是一个单调栈,索引对应温度值栈底至栈顶递增,具体逻辑如下

当栈为空或者当前天数温度小于栈顶值时,说明当前温度还不够高,不能解决任何等待中的天数的需求,所以直接推入当前天数;当当前天数大于栈顶值时,说明正是栈顶天数想要的,此时pop,保存数据,并循环判断,最后同样要压入当前天数。

可以这样理解,压栈是为了保存过去的数据,后续找到想找到值才让其出栈,通过维持一个单调栈,动态记录结果。

http://www.xdnf.cn/news/17356.html

相关文章:

  • 玩转 InfluxDB 3:用 HTTP API 快速创建高效数据表
  • Java高频方法总结
  • 数据结构(四)内核链表、栈与队列
  • 嵌入式 - 数据结构:栈和队列
  • 大数据之Flume
  • 8.6学习总结
  • Qt菜单栏与工具栏实战
  • MySQL的约束条件:
  • 人工智能——深度学习——认识Tensor
  • 12. SELinux 加固 Linux 安全
  • cad c#二次开发 图层封装 获取当前层
  • LeetCode 分类刷题:611. 有效三角形的个数
  • VGG16训练和测试Fashion和CIFAR10
  • Verilog 仿真问题:打拍失败
  • jdk动态代理如何实现
  • 对 .NET线程 异常退出引发程序崩溃的反思
  • 八股——IM项目
  • C++ 运算符重载:避免隐式类型转换的艺术
  • 译 | 在 Python 中从头开始构建 Qwen-3 MoE
  • 【ArcGIS】分区统计中出现Null值且Nodata无法忽略的问题以及shp擦除(erase)的使用——以NDVI去水体为例
  • 最新教程 | CentOS 7 下 MySQL 8 离线部署完整手册(含自动部署脚本)
  • vite项目中集成vditor文档编辑器
  • 低代码系统的技术深度:超越“可视化操作”的架构与实现挑战
  • 【机器学习篇】02day.python机器学习篇Scikit-learn基础操作
  • 疯狂星期四文案网第30天运营日记
  • 自学嵌入式 day43 中断系统
  • 数据结构与算法的认识
  • Linux 防火墙(firewalld)详解与配置
  • 【概念学习】早期神经网络
  • IPS知识点