描述
编写一个 StockSpanner 类,它收集某些股票的每日报价,并返回该股票当日价格的跨度。
今天股票价格的跨度被定义为股票价格小于或等于今天价格的最大连续日数(从今天开始往回数,包括今天)。
例如,如果未来7天股票的价格是 [100, 80, 60, 70, 60, 75, 85],那么股票跨度将是 [1, 1, 1, 2, 1, 4, 6]。
在线评测地址:领扣题库官网
样例1 输入:prices = [100,80,60,70,60,75,85] 输出:[1,1,1,2,1,4,6] 首先,初始化 S = StockSpanner(),然后: S.next(100) 被调用并返回 1, S.next(80) 被调用并返回 1, S.next(60) 被调用并返回 1, S.next(70) 被调用并返回 2, S.next(60) 被调用并返回 1, S.next(75) 被调用并返回 4, S.next(85) 被调用并返回 6。 注意 (例如) S.next(75) 返回 4,因为截至今天的最后 4 个价格 (包括今天的价格 75) 小于或等于今天的价格。
输入:prices = [50,80,80,70,90,75,85] 输出:[1,2,3,1,5,1,2] 首先,初始化 S = StockSpanner(),然后: S.next(50) 被调用并返回 1, S.next(80) 被调用并返回 2, S.next(80) 被调用并返回 3, S.next(70) 被调用并返回 1, S.next(90) 被调用并返回 5, S.next(75) 被调用并返回 1, S.next(85) 被调用并返回 2。
解题思路
单调栈问题 题目中提到股票价格小于或等于今天价格的最大连续日数。 由于这是一个在线问题,所以我们必然是要将输入的price给存储起来,而且同时我们也需要保留这是第几次输入的信息。 需要注意的是边界问题,当我们输入第一个price的时候,此时stack空。 所以这里拿出来判断特殊处理一下
源代码
public class StockSpanner { public StockSpanner() { * @param price: * @return: int Stack int[] stack = new Stack (); public int next(int price) { // Write your code here. int res = 1; while (!stack.isEmpty() stack.peek()[0] = price) res += stack.pop()[1]; stack.push(new int[]{price, res}); return res; }
更多题解参考:九章官网solution
街舞对王牌?一定会很好玩。吴建豪说。7月12日他亮相2019天猫双11狂欢夜(以下简称...
从最初的做数据管理工作,到逐渐负责指标体系梳理、预警机制搭建、BI系统建设、...
如何在 云主机 上搭 建网站 ?对站长来说,搭建网站要根据自身情况来定,若不懂...
本文转载自微信公众号「crossoverJie」,作者crossoverJie。转载本文请联系cross...
来源 | 阿里飞天CIO学堂微信公众号 “数字化是非常重要的必备基础武器,没有数字...
现如今,智慧城市建设已成为全球城市发展的必然趋势,全球仅亚太地区就已规划建...
香港虚拟主机 有什么用?香港 虚拟主机 其实和其他国内虚拟主机在使用上没有任何...
1. 接口描述 接口请求域名: cvm.tencentcloudapi.com 。 本接口(DescribeImageQ...
阿里云天池读书会四月场来啦 这次我们邀请到了《可解释机器学习》译者、复旦大学...
分布式应用运行时Dapr目前已经发布了1.1.0版本,阿里云也在积极地为Dapr贡献代码...