【栈 - LeetCode】739.每日温度

739. 每日温度 - 力扣(LeetCode)

题解

暴力+技巧

官网给的一个暴力遍历的方式,技巧点在于,温度的最大值是 100, 因此里面的 for 循环可以通过控制最大是到 100 来降低时间复杂度。

class Solution {
public:vector<int> dailyTemperatures(vector<int>& temperatures) {int n = temperatures.size();vector<int>ans(n), next(101, INT_MAX);for(int i = n - 1; i >= 0; i --){int index = INT_MAX;for(int t = temperatures[i] + 1; t <= 100; t ++){index = min(index, next[t]);}if(index != INT_MAX){ans[i] = index - i;}next[temperatures[i]] = i;}return ans;}
};

单调栈

栈中存储还没有被找到的 满足条件的 第 x 天。

如果是递增序列,栈中始终就一个元素,不断移入移出。

如果是非递增,则一直入栈,找到第一个大于栈顶的,再依次出栈判断。

class Solution {
public:vector<int> dailyTemperatures(vector<int>& temperatures) {int n = temperatures.size();vector<int> ans(n);stack<int> s;for (int i = 0; i < n; i++) {while (!s.empty() && temperatures[i] > temperatures[s.top()]) {int index = s.top();ans[index] = i - index;s.pop();}s.push(i);}return ans;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/94549.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/94549.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【无标题】对于11维拓扑量子色动力学模型来解决纳维尔-斯托克斯方程(N-S方程)全局光滑解存在性的论证可行性,从数学和物理角度进行的严谨、系统性论证与分析。

对于11维拓扑量子色动力学模型来解决纳维尔-斯托克斯方程&#xff08;N-S方程&#xff09;全局光滑解存在性的论证可行性&#xff0c;从数学和物理角度进行的严谨、系统性论证与分析。评价与核心思想该证明的核心思想是将三维流体的湍流动力学视为一个更高维&#xff08;11维&a…

朴素贝叶斯三大概率模型学习总结与手写数字识别实践

一、朴素贝叶斯模型分类与核心原理朴素贝叶斯算法的核心是基于 “特征条件独立性假设”&#xff0c;通过贝叶斯公式计算后验概率实现分类。根据特征数据类型的差异&#xff0c;衍生出三大经典模型&#xff0c;分别适用于不同场景&#xff0c;其核心区别在于对 “特征条件概率”…

学习Java26天(线程方法和线程安全)(synchronized)

170/199线程安全问题同步代码块同步方法以及lock锁同步方法Lock锁finally不管上面是否异常都会执行

网络协议---TCP

一、UDP协议1. 核心特点数据传输方式&#xff1a;面向数据包传输。连接特性&#xff1a;无需建立连接即可通信。可靠性&#xff1a;尽最大努力交付&#xff0c;存在数据丢包、乱序等问题&#xff0c;安全性和可靠性较低。传输范围&#xff1a;支持一对一、一对多的传输模式。资…

构建AI智能体:十三、大数据下的“搭积木”:N-Gram 如何实现更智能的语义搜索

一、什么是 N-gram核心定义&#xff1a;N-gram 是来自给定文本或语音序列的 N 个连续项&#xff08;如单词、字符&#xff09; 的序列。它是一种通过查看一个项目的前后文来建模序列的概率模型。N&#xff1a; 代表连续项的数量。项&#xff08;Item&#xff09;&#xff1a; 通…

嵌入式系统学习Day22(进程)

无人机运行程序&#xff0c;时间贴合阻塞态&#xff1a;程序运行到scanf或gets时的状态linux是抢占式操作系统&#xff0c;优先级高的调度高&#xff0c;优先级相同在同样时间内调度相同ip为指针&#xff0c;指向目前已读到进程的位置&#xff0c;回写到磁盘&#xff0c;进行下…

【51单片机】【protues仿真】基于51单片机冰箱系统

目录 一、主要功能 二、使用步骤 三、硬件资源 四、软件设计 五、实验现象 一、主要功能 1、LCD1602液晶显示冷藏冷冻温度值 2、按键设置温度阈值​ 3、冷藏或冷冻温度高于阈值启动制冷片 4、限位器开关检测门状态&#xff0c;开门过长蜂鸣器警报 5、状态指示灯&#xf…

征程 6X 常用工具介绍

一、采集/设置系统信息的工具集 获取开发板 SOM 状态工具 [LINUX] hrut_somstatus 是用来获取当前开发板SOM状态的工具&#xff0c;包含温度、 cpu频率、bpu状态。 用法&#xff1a; hrut_somstatus [-n count] [-d second]获取开发板boardid工具 [LINUX] hrut_boardid 是用来获…

数字隔离器:新能源系统的安全与效能革命

在新能源技术高速发展的浪潮中&#xff0c;高压、高频、高可靠性的需求对系统设计提出全新挑战。传统隔离器件受限于响应速度、抗干扰能力及体积限制&#xff0c;逐渐难以满足光伏发电、电动汽车、储能系统等场景的严苛要求。数字隔离器以创新的半导体技术为核心&#xff0c;通…

算法训练营day58 图论⑧ 拓扑排序精讲、dijkstra(朴素版)精讲

本篇应该是图论的经典部分了&#xff0c;本篇的内容作为小白没有了解过&#xff0c;但是至少会听说过——拓扑排序精讲、dijkstra&#xff08;朴素版&#xff09;精讲。 拓扑排序精讲 本题是拓扑排序的经典题目。一聊到 拓扑排序&#xff0c;一些录友可能会想这是排序&#xf…

如何在日常开发中高效使用 Copilot

网罗开发&#xff08;小红书、快手、视频号同名&#xff09;大家好&#xff0c;我是 展菲&#xff0c;目前在上市企业从事人工智能项目研发管理工作&#xff0c;平时热衷于分享各种编程领域的软硬技能知识以及前沿技术&#xff0c;包括iOS、前端、Harmony OS、Java、Python等方…

使用Docker部署Coze Studio开源版

1、安装Docker# 安装Docker https://docs.docker.com/get-docker/# 安装Docker Compose https://docs.docker.com/compose/install/# CentOS安装Docker https://mp.weixin.qq.com/s/nHNPbCmdQs3E5x1QBP-ueA2、安装Coze Studio详见&#xff1a;https://github.com/coze-dev/coze…

深度剖析Spring AI源码(九):构建企业知识库,深入ETL与RAG实现

深度剖析Spring AI源码&#xff08;九&#xff09;&#xff1a;构建企业知识库&#xff0c;深入ETL与RAG实现 “Data is the new oil, but like oil, it’s valuable only when refined.” —— 在AI时代&#xff0c;原始数据需要经过精心的ETL处理才能成为AI的"燃料"…

C# 简单工厂模式:构建灵活与可扩展的面向对象程序

在面向对象编程&#xff08;OOP&#xff09;的世界中&#xff0c;简单工厂模式&#xff08;Simple Factory Pattern&#xff09; 是一种非常常见且实用的设计模式。虽然它并不属于GoF&#xff08;Gang of Four&#xff09;定义的23种经典设计模式之一&#xff0c;但它是理解更复…

全面解析JVM预热:原理、价值与实践指南

在Java应用的性能优化领域,“JVM预热”是一个常被提及却容易被忽视的关键环节。尤其是在高并发、低延迟的业务场景中,未经过充分预热的JVM可能导致应用启动初期出现响应延迟、吞吐量波动甚至服务不可用的问题。本文将从JVM预热的核心原理出发,深入剖析其价值、常见实现方案及…

数学建模-灰色关联分析(GRA)

目录 1-AI带你认识GRA &#x1f4d8; 一、灰色关联分析&#xff08;GRA&#xff09;简介 1. 什么是灰色关联分析&#xff1f; 2. 核心思想&#xff08;通俗理解&#xff09;&#xff1a; 3. 与熵权法的对比&#xff08;快速类比&#xff09;&#xff1a; &#x1f9e9; 二…

Shell脚本-expect

一、前言在 Linux 系统管理与自动化运维中&#xff0c;我们经常需要编写 Shell 脚本来完成各种任务。但有些命令&#xff08;如 ssh、scp、passwd、ftp 等&#xff09;在执行时会等待用户手动输入密码或确认信息&#xff0c;这就导致脚本无法完全自动化运行。为了解决这个问题&…

Conmi的正确答案——Ubuntu24.04禁用任何休眠

系统&#xff1a;Ubuntu 24.04步骤一、禁用系统休眠服务 # 禁用所有休眠/待机相关服务&#xff08;立即生效&#xff09; sudo systemctl mask sleep.target suspend.target hibernate.target hybrid-sleep.target # 验证状态&#xff08;显示 "masked" 即成功&am…

开源 C++ QT Widget 开发(二)基本控件应用

文章的目的为了记录使用C 进行QT Widget 开发学习的经历。临时学习&#xff0c;完成app的开发。开发流程和要点有些记忆模糊&#xff0c;赶紧记录&#xff0c;防止忘记。 相关链接&#xff1a; 开源 C QT Widget 开发&#xff08;一&#xff09;工程文件结构-CSDN博客 开源 C…

今日科技风向|从AI芯片定制到阅兵高科技展示——聚焦技术前沿洞察

今日科技风向&#xff5c;从AI芯片定制到阅兵高科技展示——聚焦技术前沿洞察 一、NVIDIA 开发“黑曜”子版 AI 芯片 B30A&#xff0c;瞄准中国市场 今日报道指出&#xff0c;NVIDIA 正在研发一款面向中国市场的定制芯片 B30A&#xff0c;基于其先进的 Blackwell 架构&#xff…