933. Number of Recent Calls

Обновлено: 2024-03-12
1 мин
[Queue Easy]

LeetCode задача 933

Задача

Реализуйте класс RecentCounter для подсчета вызовов ping за последние 3000 миллисекунд.

Т.е. для вызова t=100, нужно подсчитать количество таких вызовов, время которых меньше t-3000 и учесть сам вызов.

Подход

В данной задаче нужно отслеживать количество вызовов ping за последние 3000 миллисекунд.

Можно использовать очередь для хранения времени вызовов ping. При каждом новом вызове будем добавлять текущее время в конец очереди и удалять из начала все времена, которые не попадают в интервал последних 3000 миллисекунд.

Таким образом, размер очереди в любой момент времени будет равен числу вызовов ping за последние 3000 миллисекунд.

Алгоритм

  1. Инициализация: создать пустую очередь для хранения времени вызовов ping.
  2. При каждом вызове ping(t):
    • Добавить t в конец очереди.
    • Удалить из начала очереди все элементы, меньшие чем t - 3000.
  3. Вернуть размер очереди.

Решение

from collections import deque

class RecentCounter:

    def __init__(self):
        self.queue = deque()

    def ping(self, t: int) -> int:
        self.queue.append(t)
        
        while self.queue[0] < t - 3000:
            self.queue.popleft()
        
        return len(self.queue)