Search⌘ K
AI Features

Solution: Moving Average from Data Stream

Explore implementing a MovingAverage class that calculates the moving average over a fixed-size sliding window of integers. Understand how to use a queue and a running sum to efficiently update the average with each new input, ensuring constant time complexity for each operation.

Statement

Given a stream of integers and a window size, calculate the moving average of all integers in the sliding window. Implement a class called MovingAverage that has the following methods:

  • Constructor (int size): This constructor initializes the object with the specified window size.

  • double next (int val): This method takes an integer value as input and returns the moving average of the last size values from the stream.

Constraints:

  • 11 \leq size ...