V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
hakunamatata11
V2EX  ›  推广

[leetcode/lintcode 题解] 微软面试题:股票价格跨度

  •  
  •   hakunamatata11 · 2020-07-24 17:32:16 +08:00 · 635 次点击
    这是一个创建于 1434 天前的主题,其中的信息可能已经有所发展或是发生改变。

    编写一个 StockSpanner 类,它收集某些股票的每日报价,并返回该股票当日价格的跨度。

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

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

    • 调用 StockSpanner.next(int price) 时,将有 1 <= price <= 10^5 。
    • 每个测试用例最多可以调用 10000 次 StockSpanner.next 。
    • 在所有测试用例中,最多调用 150000 次 StockSpanner.next 。
    • 此问题的总时间限制减少了 50%。

    样例 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) 小于或等于今天的价格。
    

    样例 2:

    输入: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;
        }
    }
    
    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5099 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 06:59 · PVG 14:59 · LAX 23:59 · JFK 02:59
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.