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

每日一道leetcode(增加版)

901. 股票价格跨度 - 力扣(LeetCode)

题目

设计一个算法收集某些股票的每日报价,并返回该股票当日价格的 跨度 。

当日股票价格的 跨度 被定义为股票价格小于或等于今天价格的最大连续日数(从今天开始往回数,包括今天)。

  • 例如,如果未来 7 天股票的价格是 [100,80,60,70,60,75,85],那么股票跨度将是 [1,1,1,2,1,4,6] 。

实现 StockSpanner 类:

  • StockSpanner() 初始化类对象。
  • int next(int price) 给出今天的股价 price ,返回该股票当日价格的 跨度 。

示例:

输入
["StockSpanner", "next", "next", "next", "next", "next", "next", "next"]
[[], [100], [80], [60], [70], [60], [75], [85]]
输出
[null, 1, 1, 1, 2, 1, 4, 6]

解释:
StockSpanner stockSpanner = new StockSpanner();
stockSpanner.next(100); // 返回 1
stockSpanner.next(80);  // 返回 1
stockSpanner.next(60);  // 返回 1
stockSpanner.next(70);  // 返回 2
stockSpanner.next(60);  // 返回 1
stockSpanner.next(75);  // 返回 4 ,因为截至今天的最后 4 个股价 (包括今天的股价 75) 都小于或等于今天的股价。
stockSpanner.next(85);  // 返回 6

提示:

  • 1 <= price <= 105
  • 最多调用 next 方法 104 次

思路

  1. 和上一个单调栈的问题也很类似,维护一个保存价格和跨度的栈,当栈为空或者price小于栈顶元素的价格时,入栈并返回1;
  2. 反之如果栈顶不为空且price大于栈顶元素的价格时,那么就不断弹栈将栈顶元素的跨度加起来,最后达到终止条件后再加上本身的1作为最终跨度,然后将此跨度入栈并返回跨度。

代码实现

class StockSpanner {
public:vector<pair<int, int>> stock_days;StockSpanner() {}int next(int price) {if(stock_days.empty()) {stock_days.push_back(make_pair(price, 1));return 1;}else {int day = 1;while(!stock_days.empty() && price >= (stock_days.back()).first) {day += (stock_days.back()).second;stock_days.pop_back();}stock_days.push_back(make_pair(price, day));return day;}}
};/*** Your StockSpanner object will be instantiated and called as such:* StockSpanner* obj = new StockSpanner();* int param_1 = obj->next(price);*/

复杂度分析

  • 时间复杂度:next操作的时间复杂度最坏为O(n)。
  • 空间复杂度:O(n)。
http://www.xdnf.cn/news/7287.html

相关文章:

  • 力扣网-复写零
  • 面试题之进程 PID 分配与回收算法:从理论到 Linux 内核实现
  • 深度学习 TensorFlow vs PyTorch
  • ubuntu 20.04 ping baidu.coom可以通,ping www.baidu.com不通 【DNS出现问题】解决方案
  • 【QT】QT6添加现有.c .h文件
  • 【愚公系列】《Manus极简入门》048-自然探险之旅:“户外活动规划师”
  • 【Spring Boot后端组件】SpringMVC介绍及使用
  • Android 11.0 动画缩放默认值改为0.5的功能实现
  • 电脑闪屏可能的原因
  • 微信学习之导航功能
  • linux编译安装srs
  • 第二届parloo杯的RSA_Quartic_Quandary
  • JAVA Web 期末速成
  • 题目练习之综合运用
  • el-tree结合el-tree-transfer实现穿梭框里展示树形数据
  • 电子电路:什么是静态工作点Q点?
  • 零基础设计模式——大纲汇总
  • 【Dify 前端源码解读系列】聊天组件功能分析文档
  • EtherCAT通讯框架
  • Node-Red通过Profinet转ModbusTCP采集西门子PLC数据配置案例
  • 开源表单设计器FcDesigner配置多语言教程
  • Go内存管理
  • 项目中把webpack 打包改为vite 打包
  • [CSS3]属性增强2
  • iOS热更新技术要点与风险分析
  • k8s节点维护的细节
  • SEO长尾词与关键词优化策略
  • Uniapp中动态控制scroll-view滚动的方式
  • Spring IOCDI————(1)
  • AG-UI 协议是什么?MCP、A2A 后,AI 领域又新增 AG-UI 协议