lecture-2026-04-07.md
markdown
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:
sizefield must equal length walked from head.
Questions for office hours
- Why not use Python
listfor everything in homework if industry does?
Answer (from slide footer) — Pedagogy: you implement to see why the optimizations exist.
Homework link
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