739. Daily Temperatures——hash

题目分析:1、用堆栈,存储降序的index,当前值比stack中最后一个值大则pop并输出距离,当前值比最后一个值小则append

2、用字典,从最后一个开始,如果有重复的温度,那么记录的是靠前的一个

class Solution:
    def numSubarrayProductLessThanK(self, T):
        # ans = []


        # for i in range(len(T)):
        #     right = i+1
        #     count = 1
        #     while right < len(T):
        #         if T[i] >= T[right]:
        #             count += 1
        #             right += 1
        #         else:
        #             ans.append(count)
        #             break
        #     if right == len(T):
        #         ans.append(0)
        # return ans

        # ans = [0] * len(T)
        # stack = []
        # for i in range(len(T)):
        #     while stack and T[stack[-1]] < T[i]:
        #         cur = stack.pop()
        #         ans[cur] = i - cur
        #     stack.append(i)
        # return ans

        nxt = [float('inf')] * 102
        ans = [0] * len(T)
        for i in range(len(T) - 1, -1, -1):
            warmer_index = min(nxt[t] for t in range(T[i]+1, 102))
            if warmer_index < float('inf'):
                ans[i] = warmer_index - i
            nxt[T[i]] = i
        return ans
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值