Course Summary Course Objectives Learning Outcomes Course Materials Teaching Methods Weekly Topics Course Schedule Office Hours Assestment ECTS Calculation Course Policies Learning Tips Print Syllabi Download as PNG

CS502 Computational Complexity

Syllabus   |  International University of Sarajevo  -  Last Update on Mar 03, 2026

Referencing Curricula

Syllabus Quick Jump

Search and navigate to any syllabus instantly

HOSTED BY

Computer Sciences and Engineering

- - | 6 ECTS Credits | International University of Sarajevo

Academic Year
-
Semester
-
Course Code
CS502
Weekly Hours
3 Teaching + 2 Practice
ECTS
6
Prerequisites
None
Teaching Mode Delivery
Online
Prerequisite For
-
Teaching Mode Delivery Notes
-
Cycle
II Cycle
Prof. Jane Doe

TBA

Course Lecturer

Position
-
Email
-
Phone
033 957
Assistant(s)
-
Assistant E-mail
-

Course Objectives

Computational Complexity course will cover important concepts from computability and complexity theories such as languages, computation models, decidability problems, P and NP problems, techniques for designing efficient algorithms for complex problems as well as approximation and randomized algorithms when problems are computationally intractable.

Learning Outcomes

After successful completion of the course, the student will be able to:

1
Understand key aspects of computational complexity such as computability vs. complexity, decidability vs. recognizability, P vs. NP.
2
Analyze the computational limitations of different computational models.
3
Apply advanced algorithm design techniques for solving computationally complex problems.
4
Understand the role of approximation and randomized algorithms in solving computationally intractable problems.
5
Use modern programming tools to apply obtained knowledge in solving real-life problems.

Course Materials

Required Textbook

1. Michael Sipser (2013) Introduction to the Theory of Computation, 3Ed, Cengage Learning, ISBN 978-1-133-18779-0 2. Thomas Cormen, Charles Leiserson, Ronald Rivest, Clifford Stein (2009) Introduction to Algorithms, 3Ed, MIT Press, ISBN 978-0-262-03384-8

Additional Literature

Teaching Methods

Class lecturing and discussions with examples
Active practical sessions for engaged learning and continuous feedback on progress
Home assignments for analyzing the obtained knowledge in the classes
Programming assignments and projects for applying obtained experience in the classes for real-life problems

Weekly Topics

This weekly planning is subject to change with advance notice.
Week Topic Readings / References
1 Languages and Computability: Countability, Computability, Functions and Languages Sipser Chapters 0, 1
2 Turing Machines: Formal Description, Configuration and Computation, Examples Sipser Chapter 3.1
3 Church-Turing Thesis: Variation of Turing Machines, RAM Model, Equivalence Sipser Chapter 3.2
4 Universality: Encoding, Universal Turing Machines, Recognizability and Decidability Sipser Chapter 3.3
5 Undecidability: Diagonalization, Mapping Reduction, Halting Problem, Rice Theorem Sipser Chapters 4. 5
6 P and NP: Asypmtotic Analysis, P-Class, Nondeterministic Turing Machines, NP-Class Sipser Chapters 7.1-7.3
7 NP-Completeness I: The Hardest Problems, Polynomial Reductions Sipser Chapter 7.4
8 Midterm Examination: Revision, Preparation, Exam
9 NP-Completeness II: Independent Set, Vertex Cover, NP Completeness, Cook-Levin Theorem Sipser Chapters 7.4, 7.5
10 NP Complete Problems: 3CNF, INDSET, Subset Sum Sipser Chapters 7.5, 7.6
11 Dynamic Programming: Edit Distance Problem, Chain Matrix Multiplication, All Pairs Shortest Path CLRS Chapter 15
12 Fast Fourier Transform: Convolution, Multiplying Polynomials, Butterfly Network CLRS Chapter 30
13 Maximum Flow: Flow Networks, Residual Networks, Ford-Fulkerson, Edmonds-Karp Algorithms CLRS Chapter 26
14 Approximation Algorithms: Min Vertex Cover, Maximum Independent Set, TSP, Metric TSP CLRS Chapter 35
15 Randomized Algorithms: Verifying Polynomial Identities, Monte-Carlo vs. Las Vegas, Min-Cut CLRS Chapter 35

Course Schedule (All Sections)

Course Schedules with all sections will be available here soon.

Office Hours & Room

Course Office hours will be available here soon.

Assessment Methods and Criteria

Assessment Components

35%x1
Final Exam
AI: Not Allowed

Alignment with Learning Outcomes :  1  2  4

15%x1
Projects
AI: Not Allowed

Alignment with Learning Outcomes :  3  5

30%x6
Class assignments
AI: Not Allowed

Alignment with Learning Outcomes :  1  2

20%x4
Home assignments
AI: Not Allowed

Alignment with Learning Outcomes :  2  4

IUS Grading System

Grading Scale IUS Grading System IUS Coeff. Letter (B&H) Numerical (B&H)
0 - 44 F 0 F 5
45 - 54 E 1
55 - 64 C 2 E 6
65 - 69 C+ 2.3 D 7
70 -74 B- 2.7
75 - 79 B 3 C 8
80 - 84 B+ 3.3
85 - 94 A- 3.7 B 9
95 - 100 A 4 A 10

IUS Grading System

Letter marks that do not affect student's CGPA:
  • "IP" – In progress is assigned for recording unfulfilled student obligations related to graduation project/thesis/dissertation and internship.
  • "S" – Satisfactory is assigned to a student who passed the examinations that are not numerically graded or whose written assignment has been accepted.
  • "U" – Unsatisfactory is assigned to a student who failed to pass the examinations that are not numerically graded.
  • "W" – Withdrawal signifies that student has withdrawn from the relevant course.
Additional letter mark that affects student's CGPA:

"N/A" – Not attending, and it is assigned to a student who is suspended from the course or who does not meet the minimal requirement for attendance on lectures or tutorials. The course lecturer must follow the attendance policy and assign "N/A" in each case of a student failing attendance.

Late Work Policy

Information about late submission policies will be shared during class and posted in this section. Please check back for official guidelines.

ECTS Credit Calculation

📚 Student Workload

This 6 ECTS credit course corresponds to 150 hours of total student workload, distributed as follows:

Lecture hours

45 hours ⏳ (15 week × 3 h)

Active tutorials

30 hours ⏳ (15 week × 2 h)

Home studies

30 hours ⏳ (15 week × 2 h)

In-term exam study

10 hours ⏳ (1 week × 10 h)

Final exam study

15 hours ⏳ (1 week × 15 h)

Home assignment study

20 hours ⏳ (10 week × 2 h)

150 Total Workload Hours

6 ECTS Credits


Course Policies

Academic Integrity

All work submitted must be your own. Plagiarism, cheating, or any form of academic dishonesty will result in disciplinary action according to university policies. When in doubt about citation practices, consult the instructor.

Attendance Policy

Students are expected to adhere to the attendance requirements as outlined in the International University of Sarajevo Study Rules and Regulations. Excessive absences, whether excused or unexcused, may impact academic performance and eligibility for assessment. Mandatory sessions (e.g., labs, workshops) require attendance unless formally exempted. For detailed policies on absences, documentation, and penalties, please refer to the official university regulations.

Technology & AI Policy

Laptops/tablets may be used for note-taking only during lectures. Phones should be silenced and put away during all class sessions. Audio/video recording requires prior permission from the instructor.

Artificial Intelligence (AI) Usage: The use of AI tools (e.g., ChatGPT, Copilot, Gemini) varies by assessment component. Please refer to the AI usage indicator next to each assessment item in the Assessment Methods and Criteria section above. Submitting AI-generated content as your own work, where AI is not explicitly allowed, constitutes an academic integrity violation.

Communication Policy

All course-related communication should occur through official university channels (institutional email or SIS). Emails should include [CS502] in the subject line.

Academic Quality Assurance Policy

Course Academic Quality Assurance is achieved through Semester Student Survey. At the end of each academic year, the institution of higher education is obliged to evaluate work of the academic staff, or the success of realization of the curricula.

More info

Article 112: Evaluation of Work of the Academic Staff

  1. At the end of each academic year, the institution of higher education is obliged to evaluate work of the academic staff, or the success of realization of the curricula.
  2. Evaluation of work of each academic staff member is to be carried out in accordance with the Statute of the institution of higher education by the institution as well as by students.
  3. The institutions of higher education are obliged to carry out a students’ evaluation survey on the academic staff performance after the end of each semester, or after the completed teaching cycle for the subject taught.
  4. Evaluation must evaluate: lecture quality, student-academic staff interaction, correctness of communication, teacher’s attitudes towards students attending the teaching activities and at assessments, availability of suggested reading material, attendance and punctuality of the teacher, along with other criteria which are defined in the Statute.
  5. The institution of higher education by a specific act determines the procedure for evaluation of the academic staff performance, the content of survey forms, the manner of conducting the evaluation, grading criteria for the evaluation, as well as adequate measures for the academic staff who received negative evaluation for two consecutive years.
  6. The evaluation of the academic staff performance is an integral process of establishment the quality assurance system, or self-control and internal quality assurance.
  7. Results of the evaluation of the academic staff performance are to be adequately analyzed by the institution of higher education, and the decision of the head of the organizational unit about the employee’s work performance is an integral part of the personal file of each member of academic staff.

Learning Tips

Engage Actively

Be prepared to contribute thoughtfully during class discussions, labs, or collaborative work. Active participation deepens understanding and encourages critical thinking.

Read and Review Purposefully

Complete assigned readings or prep materials before class. Take notes, highlight key ideas, and jot down questions. Aim to grasp core concepts and their applications—not just facts.

Think Critically in Assignments

Use course frameworks or methodologies to analyze problems, case studies, or projects. Begin early to allow time for reflection and refinement. Seek feedback to improve your work.

Ask Questions Early

Don’t hesitate to reach out when something is unclear. Use office hours, discussion boards, or peer networks to clarify concepts and stay on track.

Course Academic Quality Assurance: Semester Student Survey

Syllabus Last Updated on Mar 03, 2026 | International University of Sarajevo

Print Syllabus  

 

 

Referencing Curricula Print this page

Course Code Course Title Weekly Hours* ECTS Weekly Class Schedule
T P
CS502 Computational Complexity 3 2 6
Prerequisite None It is a prerequisite to -
Lecturer Office Hours / Room / Phone

Currently not available

E-mail
Assistant Assistant E-mail
Course Objectives Computational Complexity course will cover important concepts from computability and complexity theories such as languages, computation models, decidability problems, P and NP problems, techniques for designing efficient algorithms for complex problems as well as approximation and randomized algorithms when problems are computationally intractable.
Textbook 1. Michael Sipser (2013) Introduction to the Theory of Computation, 3Ed, Cengage Learning, ISBN 978-1-133-18779-0 2. Thomas Cormen, Charles Leiserson, Ronald Rivest, Clifford Stein (2009) Introduction to Algorithms, 3Ed, MIT Press, ISBN 978-0-262-03384-8
Additional Literature
Learning Outcomes After successful  completion of the course, the student will be able to:
  1. Understand key aspects of computational complexity such as computability vs. complexity, decidability vs. recognizability, P vs. NP.
  2. Analyze the computational limitations of different computational models.
  3. Apply advanced algorithm design techniques for solving computationally complex problems.
  4. Understand the role of approximation and randomized algorithms in solving computationally intractable problems.
  5. Use modern programming tools to apply obtained knowledge in solving real-life problems.
Teaching Methods Class lecturing and discussions with examples. Active practical sessions for engaged learning and continuous feedback on progress. Home assignments for analyzing the obtained knowledge in the classes. Programming assignments and projects for applying obtained experience in the classes for real-life problems.
Teaching Method Delivery Online Teaching Method Delivery Notes
WEEK TOPIC REFERENCE
Week 1 Languages and Computability: Countability, Computability, Functions and Languages Sipser Chapters 0, 1
Week 2 Turing Machines: Formal Description, Configuration and Computation, Examples Sipser Chapter 3.1
Week 3 Church-Turing Thesis: Variation of Turing Machines, RAM Model, Equivalence Sipser Chapter 3.2
Week 4 Universality: Encoding, Universal Turing Machines, Recognizability and Decidability Sipser Chapter 3.3
Week 5 Undecidability: Diagonalization, Mapping Reduction, Halting Problem, Rice Theorem Sipser Chapters 4. 5
Week 6 P and NP: Asypmtotic Analysis, P-Class, Nondeterministic Turing Machines, NP-Class Sipser Chapters 7.1-7.3
Week 7 NP-Completeness I: The Hardest Problems, Polynomial Reductions Sipser Chapter 7.4
Week 8 Midterm Examination: Revision, Preparation, Exam
Week 9 NP-Completeness II: Independent Set, Vertex Cover, NP Completeness, Cook-Levin Theorem Sipser Chapters 7.4, 7.5
Week 10 NP Complete Problems: 3CNF, INDSET, Subset Sum Sipser Chapters 7.5, 7.6
Week 11 Dynamic Programming: Edit Distance Problem, Chain Matrix Multiplication, All Pairs Shortest Path CLRS Chapter 15
Week 12 Fast Fourier Transform: Convolution, Multiplying Polynomials, Butterfly Network CLRS Chapter 30
Week 13 Maximum Flow: Flow Networks, Residual Networks, Ford-Fulkerson, Edmonds-Karp Algorithms CLRS Chapter 26
Week 14 Approximation Algorithms: Min Vertex Cover, Maximum Independent Set, TSP, Metric TSP CLRS Chapter 35
Week 15 Randomized Algorithms: Verifying Polynomial Identities, Monte-Carlo vs. Las Vegas, Min-Cut CLRS Chapter 35
Assessment Methods and Criteria Evaluation Tool Quantity Weight Alignment with LOs AI Usage
Final Exam 1 35 1,2,4 Not Allowed
Semester Evaluation Components
Projects 1 15 3,5 Not Allowed
Class assignments 6 30 1,2 Not Allowed
Home assignments 4 20 2,4 Not Allowed
***     ECTS Credit Calculation     ***
 Activity Hours Weeks Student Workload Hours Activity Hours Weeks Student Workload Hours
Lecture hours 3 15 45 Active tutorials 2 15 30
Home studies 2 15 30 In-term exam study 10 1 10
Final exam study 15 1 15 Home assignment study 2 10 20
        Total Workload Hours = 150
*T= Teaching, P= Practice ECTS Credit = 6
Course Academic Quality Assurance: Semester Student Survey Last Update Date: 27/03/2026

Print this page