lecture-2026-04-07.md markdown
36 lines 1.3 KB
Raw
sha256:65ccb454656ea5acdea0a10e559b78bcde1eb6ff753ecc2911bc99d1c3d7cadd feat(calendar): enforce agent context tiers in retrieval AP… Human minor ⚠ breaking 1 day ago

title: "Lecture notes — 2026-04-07 (abstract data types)" project: "cs101-intro" tags:

  • lecture
  • study-notes
  • cs101 date: 2026-04-07

Lecture 2026-04-07 — Abstract data types

Source — Live lecture + import from audio transcription (Otter.ai export, cleaned 2026-04-07 evening).

Summary (5 bullets)

  • ADT = behavior contract separate from implementation.
  • List ADT can be array-backed or linked; tradeoffs: cache locality vs. insert cost.
  • Iterator pattern hides internal structure from client code.
  • Big-O today focused on worst case unless stated otherwise.
  • Prof emphasized: choose the ADT first, then pick the implementation.

Detailed notes

  • Array list — doubling strategy keeps append amortized O(1); wasted space bounded by a constant factor.
  • Singly linked list — O(1) insert at head; need tail pointer for O(1) enqueue in naive queue.
  • Invariant example: size field must equal length walked from head.

Questions for office hours

  • Why not use Python list for everything in homework if industry does?
    Answer (from slide footer) — Pedagogy: you implement to see why the optimizations exist.

Maps directly to assignments/week-3-data-structures.md — start Stack tonight.

File History 2 commits
sha256:65ccb454656ea5acdea0a10e559b78bcde1eb6ff753ecc2911bc99d1c3d7cadd feat(calendar): enforce agent context tiers in retrieval AP… Human minor 1 day ago
sha256:9103f98c89257ed2b01c237cea895dabb3e85ea337dccb1161c175e4422355b6 docs: accept Calendar Events v0 spec with Phase 0 security … Human 2 days ago