lecture-2026-04-07.md
markdown
sha256:8915fe406161f95c1681f9469375e7bae5b28c884f00bedbdef65e4b0cd0738d
docs(flow): commit FLOW-V0-SPEC.md hygiene for 7A-INT merge
Human
12 hours 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
1 commit
sha256:8915fe406161f95c1681f9469375e7bae5b28c884f00bedbdef65e4b0cd0738d
docs(flow): commit FLOW-V0-SPEC.md hygiene for 7A-INT merge
Human
12 hours ago