CSPC 104 - Algorithms and Complexity 2nd Semester, School Year 2020-2021
CSPC 104 - Algorithms and Complexity 2nd Semester, School Year 2020-2021
Part I
Program Outcomes Upon graduation, successful BSCS graduates will attain the following program
outcomes:
1. Apply knowledge of computing fundamentals, knowledge of a computing
specialization, and mathematics, science and domain knowledge appropriate
for the computing specialization to the abstraction and conceptualization of
computing models from defined problems and requirements
6. Create, select, adapt and apply appropriate techniques, resources and modern
computing tools to complex computing activities, with an understanding of
the limitations to accomplish a common goal.
8. Communicate effectively using both English and Filipino with the computing
community and with society at large about complex computing activities by
being able to comprehend and write effective reports, design documentation
and make effective presentations, and give and understand clear instructions.
10. Recognize the need, and have the ability, to engage in independent learning
and for continual development as a computing professional.
Course Description This course aims to acquaint students with the notion of algorithms and complexity,
to present generalized techniques for the design and analysis of algorithms for
problems that are useful in practice, to argue about the correctness of algorithms, and
to become acquainted with the notion of computational classes.
Contact 3 hours
Hours/Week
Course Outcomes At the end of the course, students should be able to: 1) use big O notation formally to
give asymptotic upper bounds on time and space complexity of algorithms; 2) choose
and apply the most appropriate algorithm design technique (divide and conquer,
backtracking, greedy, dynamic programming) for solving problems; 3) describe the
behaviour and running time of various searching, sorting and graph algorithms.
● Laboratory Work
Quizzes
Laboratory Work
Part II
Algorithms with various time and space complexity such as constant, logarithmic,
linear, quadratic, and exponential
Recurrence relations
Greedy Algorithms
Divide and Conquer
Recursive Backtracking
Sorting Algorithms
Graph Algorithms
References:
Books: