Introduction to algorithms
Course objectives
This course will introduce students to very basic algorithm design and analysis. They will learn various established algorithms for solving fundamental problems, such as sorting or searching, together with the simplest tools to analyze them. Knowledge and understanding At the end of the course students will be familiar with the basic methodologies for the design and analysis of iterative and recursive algorithms, elementary data structures, major sorting algorithms and the most basic implementations of the dictionaries. Apply knowledge and understanding: At the end of the course students will have become familiar with the main basic data structures, in particular those implementing dictionaries. They will be able to explain the algorithms and analyse their time complexity, highlighting how their performances depend on the used data structure. They will be able to design new data structures and related algorithms on the basis of the existing ones; they will be able to explain the main sorting algorithms, illustrating the underlying design strategies and their time complexity analysis; they will be able to compare the asymptotic behaviour of the execution times of the studied algorithms, to design recursive solutions to problems and to analyse their asymptotic time complexity. Critical and judgmental skills Students will be able to analyze the quality of an algorithm and related data structures, both from the effective resolution of the problem and from the time complexity point of view. Communication skills Students will acquire the ability to expose their knowledge in a clear and organized way, which will be verified both through the written tests and during the oral examination. Students will be able to express an algorithmic idea rigorously at high level, in pseudocode. Learning ability The acquired knowledge will allow students to face the study of other algorithmic design metodologies and of more advanced data structures within a master's degree course.
Program - Frequency - Exams
Course program
Prerequisites
Books
Teaching mode
Frequency
Exam mode
Lesson mode
- Lesson code1015885
- Academic year2024/2025
- CourseInformatics
- CurriculumSingle curriculum
- Year1st year
- Semester2nd semester
- SSDINF/01
- CFU6
- Subject areaFormazione informatica di base