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

力扣 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.dtcms.com/a/318202.html

相关文章:

  • Linux firewall 防火墙管理
  • SpringBoot 接入SSE实现消息实时推送的优点,原理以及实现
  • React:生命周期
  • 二、Istio流量治理(一)
  • 佳文鉴赏 || FD-LLM:用于机器故障诊断的大规模语言模型
  • 性能为王:一次从压测到调优的实战全流程复盘
  • PHP常用日期时间函数
  • 线程-线程池篇(二)
  • 【CSS】动态修改浏览器滚动条宽度
  • 楼宇自控系统对建筑碳中和目标的实现具重要价值
  • MCU程序的ARM-GCC编译链接
  • Powershell---替换文本文件中指定行的整行内容
  • K8S云原生监控方案Prometheus+grafana
  • Java throw exception时需要重点关注的事情!
  • TCP的三次握手和四次挥手实现过程。以及为什么需要三次握手?四次挥手?
  • 使用Cursor创建iOS应用
  • Xcode 26 如何在创建的 App 包中添加特定的目录
  • 北大、蚂蚁三个维度解构高效隐私保护机器学习:前沿进展+发展方向
  • 安装Chocolatey一文通
  • IPS知识点
  • Ubuntu设置
  • 从零开始用 Eclipse 写第一个 Java 程序:HelloWorld 全流程 + 避坑指南
  • Vscode 解决 git插件Failed to connect to github.com port 443 connection timed out
  • prometheus+Grafana 监控中间件项目
  • ROG 掌机 X:便携游戏新宠,开启微观生存冒险
  • 部署Web UI自动化测试平台:SeleniumFlaskTester
  • 魔法客栈 v0.74(Magic Inn)免安装中文版,破木屋逆袭五星城堡
  • Pytorch-07 如何快速把已经有的视觉模型权重扒拉过来为己所用
  • X86-ubuntu22.04远程桌面只有1/4无法正常操作
  • Linux学习-4用户/权限