CS 39: Theory of Computation
Spring 2018 | 10 hour (MWF 10:10-11:15, x-hr Th 12:15-13:05) | Sudikoff 115

This course has ended. Links to slides and notes in the table below are no longer functional.

Topics Day-by-Day

All references are to the required textbook (Sipser). Notation like "p34" refers to a particular page number; notation like "2.1" refers to a section number; notation like "Ch 3" refers to an entire chapter.

#DateTopicsReferences
1Mon Mar 26Welcome, administrivia, overview; Mathematical notation Slides; 0.1, 0.2, 0.3
2Wed Mar 28Types of proof (direct, contradiction, induction) Slides; 0.4
3Thu Mar 29Strings and languages; Finite automata; Basic DFA examples 1.1 up to p34
4Fri Mar 30Further DFA examples; formalization as (Q,Σ,δ,q0,F) 1.1
5Mon Apr 2Closure under union/intersection 1.2
6Wed Apr 4The regular operations; Regular expressions 1.3 up to p69
7Thu Apr 5Kleene's Theorem; Conversion of RegExp to NFA Notes; 1.3 up to p69
8Fri Apr 6Kleene's Theorem II: Conversion of NFA to DFA 1.3
9Mon Apr 9Kleene's Theorem III: of DFA to RegExp Notes; 1.3
10Wed Apr 11The pumping lemma; proving non-regulartiy 1.4
11Thu Apr 12Non-regularity via closure properties 1.4
12Fri Apr 13Pushdown automata; examples 2.2 up to p116
Q Mon Apr 16Quiz 1: closed notes, in class
13Wed Apr 18Formal definitions for PDAs; Closure under union, concatenation, star 2.2 up to p116
14Thu Apr 19Context-free grammars; examples 2.1 up to p106
15Fri Apr 20Formal definitions for CFGs; a sophisticated completeness proof Notes
16Mon Apr 23Ambiguity; Chomsky Normal Form 2.1
17Wed Apr 25Equivalence of CFGs and PDAs, I Notes; 2.2 up to p120
18Thu Apr 26Equivalence of CFGs and PDAs, II 2.2
19Fri Apr 27Pumping lemma for CFLs; applications 2.3
20Mon Apr 30Turing Machines; simple examples; formal definition 3.1; Simulator 1; Simulator 2
21Wed May 2Multi-tape TMs; Equivalence with single-tape TMs Slides; 3.2 up to p178
22Thu May 3Nondeterministic TMs; The RAM model; Church-Turing Thesis Slides; 3.2, 3.3
23Fri May 4Enumerator TMs; Connections with deciders/recognizers 3.2
24Mon May 7Decision problems for major language classes: ADFA, ACFG, ATM; EX, ALLX, EQX, INTX 4.1
25Wed May 9Proving undecidability and unrecognizability 4.2
26Thu May 10Catch-up (as needed) 5.1 up to p220, 5.3
27Fri May 11Reductions, mapping reductions, and their applications 5.3
Q Mon May 14Quiz 2: closed notes, in class
28Wed May 16Time complexity; P and NP 7.1, 7.2, 7.3
29Thu May 17NP-completeness and polynomial time reductions (intro) Slides; 7.4 up to p304, 7.5 up to p318
30Fri May 18NP-completeness of SAT (without proof), 3-SAT, IND-SET 7.5
31Mon May 21NP-completeness of CLIQUE, UHAMCYCLE, TSP 7.5
32Wed May 23NP-completeness of 3-COL; Tractability of 2-COL and 2-SAT 7.5
33Thu May 24Computational tableaux
34Fri May 25Undecidability of INTCFG; Unrecognizability of ALLCFG 5.1
H Mon May 28Memorial day
35Wed May 30Proof of the Cook-Levin theorem; Wrap up 7.4

As you can see, we will be using every X-hour.

Reading Homework

There is reading homework associated with every class, which consists of reading the related sections of the textbook, plus any slides or notes linked from the table above. On rare occasions, the reading will cover a theorem or a small topic that was not discussed in detail in class. In any case, this reading homework is always due before the next class. There is nothing to submit and no grade for this homework, but I assume that you will nevertheless do the homework on time, every time.

Be warned that not doing the homework will make it very hard to follow along during the next class.