Tutor (for lectures and tutorials):
- doc. Ing. Zdeněk Sawa, Ph.D. (room: EA413, e-mail: zdenek.sawa@vsb.cz)
- Terms of the exams have been published in Edison.
- The correcting test will be written on Wednesday, December 18, 2024 at 10:45 in room EB405.
- Topics of presentations were published: tcs-presentations.pdf
- The test will be written on Wednesday, November 27, 2024.
The aim of the course is to introduce students to some basics of the following areas of theoretical computer science:
Preliminary Program of Lectures
- Introduction. Algorithms and algorithmic problems. Models of computation (Turing machines, Random Access Machines). Church-Turing thesis.
- Computational complexity of algorithms. Asymptotic notation. Analysis of complexity of recursive algorithms.
- More advanced techniques of analysis and design of algorithms: amortized analysis, complexity of algorithm in an average case
- Turing machines. Computational complexity of problems. Complexity classes. Classes P and NP. Reductions between problems. NP-completeness. Some well-known NP-complete problems.
- Other complexity classes - PSPACE, EXPTIME, EXPSPACE, LOGSPACE, NLOGSPACE. Polynomial hierarchy.
- Undecidable problems. Rice' theorem.
- Randomized algorithms. Approximation algorithms.
- Computational complexity of parallel algorithms: models of computation for parallel algorithms (PRAM).
- Analysis of computational complexity of parallel algorithms. Class NC. Correspondence with circuits (circuit complexity).
- Distributed algorithms: models of computation for distributed algorithms. Communication complexity.
- Kolmogorov complexity.
- Semantics of programming languages: formal description of semantics (struktural operational semantics, denotational semantics).
- Methods for proving correctness of programs.
- Quantum computing.
Presentation
Topics for presentations will be published during the semester and each student will obtain an assigned topic.
To obtain a credit, it is necessary prepare the presentation in a written form and present it to a tutor. Students must show during these presentations that they understand the given topic. A particular term for the presentations will be specified during the semester.
It is possible to obtain up to 15 points for the presentation. It is necessary to obtain at least 5 points.
If some student does not obtain the necessary 5 points for his/her presentation, it is possible to do the presentation once again, however, the maximal number of points will be only 10 points in this case, while the required minimal number of points is 1 point.
Topics of presentation for winter semester 2024/25: tcs-presentations.pdf
Written Test
There will be a written test during the semester. It will be possible to get up to 20 points from this test, while the minimum necessary to obtain a credit is 10 points.
The test will be written on some of tutorials. Particular date will be specified during the semester.
There will be some alternative date specified for students that due to some important reasons (e.g., illness) can not attend the written test in the regular date.
Students that do not obtain the necessary 10 points from the written test will have the possibility to obtain these points on a correcting test. However, it will be possible to obtain only a 17 points and it will be still necessary to obtain at least 10 points. (Points for a credit will be assigned according to the correcting test in this case.)
It is necessary to obtain for the presentation and the written test in total at least 15 points.
It is possible to obtain up to 65 points for an exam. The exam will be in a written form.
In the exam, it is necessary to obtain at least 25 points.
Slides from Lectures
Slides from lectures from the school year 2024/2025 will be published here during the semester.
- Lecture 1
– Introduction. Algorithms and algorithmic problems. Models of computation (Turing machines and Random Access Machines). Church-Turing thesis.
Slides: tcs-slides-01.pdf
- Lecture 2
– Undecidable problems. Semidecidable problems. Examples of undecidability of problems. Rice's theorem.
Slides: tcs-slides-02.pdf
- Lecture 3
– Computational complexity of algorithms. Asymptotic notation. Complexity analysis of recursive algorithms.
Slides: tcs-slides-03.pdf
- Lecture 4
– Complexity classes. Nondeterministic algorithms.
Slides: tcs-slides-04.pdf
- Lecture 5
– NP-complete problems.
Slides: tcs-slides-05.pdf
- Lecture 6
– Examples of proofs of NP-completeness of some problems.
Slides: tcs-slides-06.pdf
- Lecture 7
– Complete problems for other complexity classes. Class PSPACE. PSPACE-complete problems.
Slides: tcs-slides-07.pdf
- Lecture 8
– Classes L and NL. Logspace reductions. P-complete problems.
Slides: tcs-slides-08.pdf
Exercises for tutorials
Exercises for tutorials for the school year 2024/2025 will be published here during the semester.
- Tutorial 1: tcs-exercises-01.pdf
- Tutorial 2: tcs-exercises-02.pdf
- Tutorial 3: tcs-exercises-03.pdf
- Tutorial 4: tcs-exercises-04.pdf
- Tutorial 5: tcs-exercises-05.pdf
- Tutorial 6: tcs-exercises-06.pdf
- Tutorial 7: tcs-exercises-07.pdf
Animations
- Animations — animations illustrating some topics discussed in the course (in Czech)
- Sipser, M.: Introduction to the Theory of Computation, PWS Publishing Company, 1997.
- Kozen, D.: Automata and Computability, Undergraduate Text in Computer Science, Springer-Verlag, 1997.
- Papadimitriou, C.: Computational Complexity, Addison Wesley, 1993.
- Arora, S., Barak, B.: Computational Complexity: A Modern Approach, Cambridge University Press, 2009.
- Hopcroft, J.E., Motwani, R., Ullman, J, D.: Introduction to Automata Theory, Languages, and Computation, (3rd edition), Addison Wesley, 2006.
- Cormen, T. H., Leiserson, R. L., Rivest, R. L., Stein, C.: Introduction to Algorithms, MIT Press, 2001.