Leetcode 359 Logger Rate limit

[Leetcode] 359 Logger Rate limit

class Logger:

    def __init__(self):
        # key=message(str), value=timestamp_last_sent(int)
        self.msg_sent = {}
        self.cap = 10
        

    def shouldPrintMessage(self, timestamp: int, message: str) -> bool:
        if message not in self.msg_sent:
            self.msg_sent[message] = timestamp
            return True 
        else:
            # check if within window
            latest_ts = self.msg_sent[message]
            if timestamp - latest_ts < self.cap:
                return False
            else:
                self.msg_sent[message] = timestamp
                return True 

接下来重要讨论下可能的follow-up

follow-up 1, 原题中限制的是 limit_per_message, 如果是我们限制 limit_per_user_per_message, 即相同用户,相同消息,我们有一个limit, 如何实现呢? 

比较直接的方法就是把这个多重限制转化成key 

# before 
# dict[message(str), timestamp]
# e.g  {"foo": 1001}
self.msg_sent = {}

# after
# dict[rate_limit_key(str), timestamp]
# e.g {"user_1::foo": 1001}
self.msg_sent = {}
key = user_id + "::" + message

follow-up 2 如果限制的不是说每X秒只能发一个,而是每X秒最多发Y个相同message, 怎么改呢? 

那么这个时候也记录最后一次消息发送的时间就不够了,我们需要记录的是最近发送的所有消息

# before 
# dict[message(str), timestamp]
# e.g  {"foo": 1001}
self.msg_sent = {}

# after
# dict[rate_limit_key(str), queue[timestamp]]
# e.g {"user_1::foo": [1001, 1002, 1005, 1010]}
self.msg_sent = {}

然后每次先把超过时间窗口的排除,然后看是否已经达到limit 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值