【LeetCode每日一题】单调栈 901股票价格跨度

901. 股票价格跨度思路

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

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

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

实现 StockSpanner 类:

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

从数组的左边找出等于或小于今天的股票的连续个数。

stack = [] 100 入栈, 80 ,80<100 ? 100 弹出。80 入栈,return stack.length

60 60<80? 80弹出,60入栈,return 1

70 70<60 ? No ⇒ 70,70入栈,return2,

60 60<70 ? yes while stack>0,70出栈,60入栈,return 1.

相关推荐
春日见2 小时前
丝滑快速拓展随机树 S-RRT(Smoothly RRT)算法核心原理与完整流程
人工智能·算法·机器学习·路径规划算法·s-rrt
Code小翊2 小时前
”回调“高级
算法·青少年编程
云里雾里!2 小时前
力扣 977. 有序数组的平方:双指针法的优雅解法
算法·leetcode·职场和发展
娃哈哈哈哈呀3 小时前
formData 传参 如何传数组
前端·javascript·vue.js
一只侯子5 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
2503_928411565 小时前
11.24 Vue-组件2
前端·javascript·vue.js
jianqiang.xue5 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
g***B7386 小时前
JavaScript在Node.js中的模块系统
开发语言·javascript·node.js
不许哈哈哈6 小时前
Python数据结构
数据结构·算法·排序算法
Z***25806 小时前
JavaScript在Node.js中的Deno
开发语言·javascript·node.js