Guarantor:Lecturer:
- doc. Ing. Zdeněk Sawa, Ph.D. (room: EA413, e-mail: zdenek.sawa@vsb.cz)
Teaching Assistants:
- doc. Ing. Zdeněk Sawa, Ph.D.
Tutor for students in the combined form:
- Mgr. Pavla Dráždilová, Ph.D.
- Ing. Martin Kot, Ph.D.
- Mgr. Marek Menšík, Ph.D.
- doc. Ing. Zdeněk Sawa, Ph.D.
- Ing. Martin Kot, Ph.D.
- 23.3.2025: The term of the written test:
- students in the English version of the course — on the tutorials on Monday, April 14, 2025 at 11:30, and Thursday, April 17, 2025 at 9:00
Tutor: Ing. Martin Kot, Ph.D (room: EA413, e-mail: martin.kot@vsb.cz)
The aim of the course is to introduce students to some basics of the following areas of theoretical computer science:
- theory of formal languages and automata,
- computability and complexity.
Preliminary Program of Lectures
- Introduction. What are the main topics of theoretical computer science (algorithms, algorithmic problems, formal languages, ...). Formal languages - basic notions (alphabet, word, language). Operations on languages.
- Regular expressions. Deterministic finite automata (DFA). Construction of DFA. Some language operations on DFA.
- Nondeterministic finite automata (NFA). Transformation of NFA to DFA. Language operations on NFA. Relation between regular expressions and finite automata.
- Context-free grammars and languages.
- Algorithmic problems. Models of computation (Turing machines and RAM machines).
- Algorithms. Church-Turing thesis. Correctness of algorithms. Methods for proving correctness of algorithms.
- Computational complexity of algorithms. Asymptotic notation. Analysis of computational complexity of algorithms.
- Undecidable problems (e.g., halting problem).
- Complexity of problems. Complexity classes (in particular classes P and NP). Reductions between problems. NP-complete problems.
- Examples of NP-complete problems and reductions between problems.
Written Test
There will be a written test during the semester. It will be possible to get up to 24 points from this test, while the minimum necessary to obtain a credit is 12 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 12 points from the written test will have the possibility to obtain these points on a correcting test. However, it will be possible to obtain at most 20 points from the correcting test. (Points for a credit will be assigned according to the correcting test in this case.)
Activity on Tutorials
It is possible to obtain up to 6 points for the actiovity on tutorials, while 3 points are the required minimum.
Requirements for Obtaining a Credit
To obtain a credit, it is necessary to obtain at least 12 points from the written test and at least 3 points for the activity on tutorials.
Students that repeat the course and got their credit last year can choose one of the following two possibilities:
- To obtain a credit with the same number of points as the last year.
- To undertake the whole course once more.
Students that either
- have a credit from the last year written in Edison but do not want to have this credit, or
- are entitled to obtain a credit from the last year and want this but it is not written in Edison
must inform the guarantor of the course if they want their credit or not at the latest during the first two weeks of the semester. Later claims will not be considered.
Students that want their credit and have it already written in Edison do not need to do anything.
No points from the last year will be assigned to students that repeat the course but do not have a credit from the last year. They must do everything once more.
It is possible to obtain up to 70 points for an exam. The exam will be in a written form.
The exam consists of two parts devoted to the following areas, it is possible to obtain up to 35 points from each part:
- theory of formal languages and automata
- complexity and computability
It is necessary to obtain at least 12 points from each of these parts.
For students, which are in the 3rd year, repeat the course and want to go to the state exam this year, there will be a special term for an exam. The content of the exam will be the same as for exams in regular terms.
- Students should prepare for tutorials.
- Exercises for tutorials will be published in advance on the web page for the course. It is assumed that every student tries to solve these exercises in advance, and on tutorials will discuss particular problems encountered when trying to solve them.
- Students are obliged to bring exercises (printed or in electronic form) to tutorials so that they do not need to lose time on tutorials by writing the statements of exercises to their notes.
- Tutorials are not a replacement of lectures! This means that basic notions from lectures will not be explained once more from scratch on tutorials because it is assumed that students already met with these notions on lectures. Tutorials will be concentrated particularly to solving exercises and explanations of things, which are not clear.
Main Texts
- Introduction to Theoretical Computer Science (author: prof. RNDr. Petr Jančar, CSc.) — (in Czech) the main study text for languages and automata and computability and complexity (prof. RNDr. Petr Jančar, CSc. is the author)
- Introduction to Theoretical Computer Science: algorithms (version from 5.1.2021) (author: doc. Ing. Zdeněk Sawa, Ph.D.) — (in Czech) the study text for algorithms, this text is not completely finished yet, it will be extended and modified during the semester
Lectures
Slides from lectures from the school year 2023/2024 will be published here during the semester.
- Lecture 1
Topic: Introduction. What are the main topics of theoretical computer science (algorithms, algorithmic problems, formal languages, ...). Formal languages. Operations on words and on languages.
Slides: in Czech, in English
- Lecture 2
Topic: Regular expressions. Deterministic finite automata. Language operations on finite automata.
Slides: in Czech, in English
- Lecture 3
Topic: Nondeterministic finite automata. Relationship between regular expressions and finite automata. Nonregular languages.
Slides: in Czech, in English
- Lecture 4
Topic: Context-free grammars.
Slides: in Czech, in English
- Lecture 5
Topic: Pushdown automata.
Slides: in Czech, in English
- Lecture 6
Topic: Turing machines. Chomsky hierarchy.
Slides: in Czech, in English
- Lecture 7
Topic: Models of computation. Variants of Turing machines. Random Access Machines.
Slides: in Czech, in English
- Lecture 8
Topic: Algorithms. Church-Turing thesis. Proving correctness of algorithms.
Slides: in Czech, in English
Exercises for tutorials
Exercises for tutorials for the school year 2023/2024 will be published during the semester:
- Tutorial 0: in Czech, in English
- Tutorial 1: in Czech, in English
- Tutorial 2: in Czech, in English
- Tutorial 3: in Czech, in English
- Tutorial 4: in Czech, in English
- Tutorial 5: in Czech, in English
- Tutorial 6: in Czech, in English
- Tutorial 7: in Czech, in English
Animations
- Animations — animations illustrating some topics discussed in Introduction to Theoretical Computer Science (in Czech)
Other Texts
- Theoretical Computer Science (author: prof. RNDr. Petr Jančar, CSc.) — (in Czech) the study text for languages and automata and computability and complexity for the course Theoretical Computer Science, it is an extendend version of the text for Introduction to Theoretical Computer Science, the text is intended for students with a deeper interest in the field
- 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.
- Gruska, J.: Foundations of Computing, International Thomson Computer Press, 1997.