π― Princeton CS unofficial reading list (Fall 2024)
Spring 2025 β
This is an unofficial list of books that are recommended in Fall 2024 computer science classes at Princeton
The books marked with a β¨ are ones Iβve been interested enough in to read at length
Freshman level | Β |
---|---|
Computers in Our World COS / EGR 109 |
β Understanding the Digital World: What You Need to Know about Computers, the Internet, Privacy & Security by Brian Kernighan |
Computer Science: An Interdisciplinary Approach COS 126 - π my notes |
β Computer Science: An Interdisciplinary Approach β¨ by Sedgewick & Wayne |
Sophomore level | Β |
---|---|
Intro. to Programming Systems COS 217 |
β C Programming: A Modern Approach by K.N. King β ARM 64-Bit Assembly Language by Pyeatt & Ughetta β β¨ The Practice of Programming β¨ by Kernighan & Pike β Linux Pocket Guide: Essential Commands by Daniel J. Barrett |
Algorithms & Data Structures COS 226 - π my notes |
β Algorithms by Sedgewick & Wayne |
Reasoning About Computation COS 240 |
β Mathematics for Computer Science by Lehman, Leighton & Meyer |
Junior level | Β |
---|---|
Mathematics for Numerical Computing & Machine Learning COS 302 |
β β¨ Mathematics for Machine Learning β¨ by Deisenroth, Faisal & Ong |
Computing & Optimization for the Physical & Social Sciences COS 323 |
β An Introduction to Optimization: With Applications to Machine Learning by Chong, Lu & Zak β Algorithms by Dasgupta, Papadimitriou & Vazirani β Introduction to Applied Linear Algebra: Vectors, Matrices& Least Squares by Boyd & Vandenberghe β Convex Optimization by Boyd & Vandenberghe |
Intro. to Machine Learning COS 324 |
β Introduction to Machine Learning by Arora, Park, Jacob & Chen β An Introduction to Statistical Learning by James, Witten, Hastie & Tibshirani β β¨ Mathematics for Machine Learning β¨ by Deisenroth, Faisal & Ong β Deep Learning by Goodfellow, Bengio & Courville β Introduction to Probability by Blitzstein & Hwang β Reinforcement Learning: An Introduction by Sutton & Barto β Programming with Python by Software Carpentry β Learning Data Science: Data Wrangling, Exploration, Visualization & Modeling with Python by Lau, Gonzalez & Nolan |
Functional Programming COS 326 |
β β¨ OCaml Programming: Correct + Efficient + Beautiful β¨ by Michael Clarkson β Real World OCaml: Functional Programming for the Masses by Madhavapeddy & Minsky |
Advanced Programming Techniques COS 333 |
β β¨ The Practice of Programming β¨ by Kernighan & Pike β Python in a Nutshell: A Desktop Quick Reference by Martelli, Ravenscroft, Hoden & McGuire β Flask Web Development: Developing Web Applications with Python by Miguel Grinberg β JavaScript: The Definitive Guide: Master the Worldβs Most-Used Programming Language by David Flanagan β Beginning Software Engineering by Rod Stephens |
Senior level | Β |
---|---|
Computer Graphics COS 426 |
β Computer Graphics with Open GL by Hearn, Baker & Carithers |
Cryptography COS 433 |
β Introduction to Modern Cryptography by Katz & Lindell β Foundations of Cryptography by Oded Goldreich β Tutorials on the Foundations of Cryptography: Dedicated to Oded Goldreich by Yehuda Lindell |
Principles of Blockchains COS 470 |
β β¨ Bitcoin & Cryptocurrency Technologies: A Comprehensive Introduction β¨ by Narayanan, Bonneau, Felten, Miller & Goldfeder |
Graduate level | Β |
---|---|
Theoretical Machine Learning COS 511 |
β Introduction to Online Convex Optimization by Elad Hazan β Introduction to Online Nonstochastic Control by Hazan & Singh β Prediction, Learning & Games by Cesa-Bianchi & Lugosi β Understanding Machine Learning: From Theory to Algorithms by Shalev-Shwartz & Ben-David β Boosting: Foundations& Algorithms by Schapire & Freund β Reinforcement Learning: Theory& Algorithms by Agarwal, Jiang, Kakade & Sun β Optimization for Machine Learning by Elad Hazan |
Optimization for Machine Learning COS 512 |
β Convex Optimization: Algorithms and Complexity by Sebastien Bubeck β Optimization for Machine Learning by Elad Hazan β Convex Optimization by Boyd & Vandenberghe |
Automated Reasoning about Software COS 516 |
β The Calculus of Computation: Decision Procedures with Applications to Verification by Bradley & Manna |
Advanced Algorithm Design COS 521 |
β Algorithmic Game Theory by Nisan, Roughgarden, Tardos & Vazirani β Randomized Algorithms by Motwani & Raghavan β Online Computation & Competitive Analysis by Borodin & El-Yaniv β The Probabilistic Method by Alon & Spencer β Approximation Algorithms by Vijay V. Vazirani β The Design of Approximation Algorithms by Williamson & Shmoys β Spectral Graph Theory by Fan R.K. Chung |
Recent Advances in Graph Algorithms COS 597B |
See website for paper list |
Programming Languages for Distributed Systems COS 597E |
See website for paper list |
AI, Society & Education COS 597H |
β Causal Inference: What If by Hernan & Robins |
Systems for Serving Generative AI COS 597K |
See website for paper list |
Deep Dive into Large Languages COS 597R |
See website for paper list |
Recent Advances in Wireless Networks COS 597S |
See website for paper list |