Skip to content

Instantly share code, notes, and snippets.

@pschanely
Created February 27, 2024 20:59
Show Gist options
  • Save pschanely/9c34e6549a5bf1c0076e6610ecb6525c to your computer and use it in GitHub Desktop.
Save pschanely/9c34e6549a5bf1c0076e6610ecb6525c to your computer and use it in GitHub Desktop.
Shared via CrossHair Playground
import dataclasses
from typing import List
@dataclasses.dataclass
class AverageableQueue:
'''
A queue of numbers with a O(1) average() operation.
inv: self._total == sum(self._values)
'''
_values: List[int]
_total: int
def push(self, val: int):
self._values.append(val)
self._total += val
def pop(self) -> int:
''' pre: len(self._values) > 0 '''
val = self._values.pop(0)
# Oops. We are forgetting to do something here.
return val
def average(self) -> float:
''' pre: self._values '''
return self._total / len(self._values)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment