“This is the 24th day of my participation in the Gwen Challenge in November. Check out the details: The Last Gwen Challenge in 2021.”

[B] [C] [D]

Write a RecentCounter class to count the most recent requests within a specific time range.

Please implement RecentCounter class:

  • RecentCounter()Initialize the counter with a request count of 0.
  • int ping(int t)In the timetAdd a new request to thetRepresents a time in milliseconds and returns to the past3000The number of all requests (including new requests) that occurred in milliseconds. To be exact, return in[t-3000, t]The number of requests that occur within.

Make sure that each call to ping uses a larger t value than before.

Example:

Input: [" RecentCounter ", "ping", "ping", "ping", "ping"] [[], [1], [100], [3001], [3002]] output: [null, 1, 2, 3, 3] :  RecentCounter recentCounter = new RecentCounter(); recentCounter.ping(1); // requests = [1], range [-2999,1], returns 1 recentCounter.ping(100); // requests = [1], range [-2999,1], returns 1 recentCounter.ping(100); // requests = [1, 100] in the range [-2900,100], returns 2 recentCounter.ping(3001); // requests = [1, 100] in the range [-2900,100], returns 2 recentCounter.ping(3001); // requests = [1, 100, 3001] in range [1,3001], return 3 recentCounter.ping(3002); // requests = [1, 100, 3001] in range [1,3001], return 3 recentCounter.ping(3002); // requests = [1, 100, 3001, 3002] in the range [2,3002], return 3Copy the code

Tip:

  • 1 <= t <= 109
  • Make sure that every timepingThat is used by the calltValues areStrictly increasing
  • Up to callpingmethods104 次

We need to record all requests in the time range from t-3000 to T and return the number of requests

And because they guarantee that each call to ping will use a larger value than the previous one, the earlier the request, the smaller the t-value, is most likely not to meet the t-3000 time requirements

So here we can use queues to maintain all requests

When a new request is invoked, determine whether the first element value is less than t-3000. If so, delete the first element until the first element value is greater than or equal to t-3000

This ensures that all values in the queue are greater than or equal to t-3000

Finally, the request t join the queue, return the number of elements in the queue

The code is as follows:

Var RecentCounter = function() {this.queue = []; }; / * * * @ param @ return {number} {number} t * * / RecentCounter prototype. Ping = function (t) {/ / when the queue is not empty and team for the first element is less than t - 3000, While (this.queue. Length && this.queue[0]<t-3000){this.queue.shift(); } this.queue. Push (t); this.queue. Push (t); this.queue. Return this.queue.length; // The length of the queue is the number of requests from t-3000 to t. };Copy the code

At this point we are done with Leetcode -933- the number of recent requests

If you have any questions or suggestions, please leave a comment!