Skip to content

Instantly share code, notes, and snippets.

@pschanely
Created November 26, 2025 12:30
Show Gist options
  • Select an option

  • Save pschanely/79ca232ed00a0854793e11a05a7d8632 to your computer and use it in GitHub Desktop.

Select an option

Save pschanely/79ca232ed00a0854793e11a05a7d8632 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