- Docente: Jocelyne Elias
- Credits: 12
- SSD: INF/01
- Language: Italian
- Moduli: Davide Rossi (Modulo 1) Jocelyne Elias (Modulo 2)
- Teaching Mode: Traditional lectures (Modulo 1) Traditional lectures (Modulo 2)
- Campus: Bologna
- Corso: First cycle degree programme (L) in Information Science for Management (cod. 8014)
-
from Sep 20, 2024 to Dec 20, 2024
-
from Feb 17, 2025 to May 14, 2025
Learning outcomes
Students will learn basic concepts about the fundamental algorithms to solve well knwon computational problems, and the basic data structures and abstract data types, as well as techniques for evaluation of computational complexity of algorithms (and computation complexity classes P, NP, NP-hard) and space complexity of algorithms execution (memory space). The course will offer the illustration of trade-offs and sinergies between algorithms and data structures, and a training on methodologies to realize the design of efficient algorithms and correspondingly appropriate data structures to solve both generalized and specific instances of computational problems, under pre-defined assumptions and requirements.
Course contents
Basic data structures (List, Queue, Stack, Trees...)
Computational Complexity
Searching and Sorting Algorithms
Sets, Dictionaries, Trees, Binary search, RB trees
Heaps, Hash tables, Priority queues, Union-Find data structures
Algorithmic techniques: divide et impera, greedy algorithms, dynamic programming,
Graphs and graph algorithms: depth-first visit and breadth-first visit,
Elementary graph algorithms, Minimum Spanning Tree, shortest paths algorithms
Introduction to NP-completeness theory
Readings/Bibliography
Official text:
Alan A. Bertossi, A. Montresor, Algoritmi e Strutture di Dati [http://www.utetuniversita.it/bertossi], CittàStudi 2010, ISBN: 9788825173567
Recommended readings:
Camil Demetrescu, Irene Finocchi, Giuseppe F. Italiano, Algoritmi e strutture dati 2/ed [http://www.ateneonline.it/demetrescu2e/homeA.asp], McGraw-Hill, 2008, ISBN: 978 88 386 64687
Camil Demetrescu, Umberto Ferraro Petrillo, Irene Finocchi, Giuseppe F. Italiano, Progetto di Algoritmi e Strutture Dati in Java [http://www.ateneonline.it/demetrescu/homeB.asp] , McGraw-Hill, 2007, ISBN: 9788838663741
Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, Clifford Stein, Introduzione agli algoritmi e strutture dati 2/ed [http://www.ateneonline.it/cormen/] , McGraw-Hill, 2005, ISBN: 9788838662515
Teaching methods
Lectures and interactive exercises.
Assessment methods
The assessment of learning takes place through the development of a project and an oral test. The aim of the project is to verify the practical ability to design and implement correct and efficient algorithms. The evaluation of the project must be at least sufficient (i.e., the assessment ≥ 18/30) to be valid for the exam. The oral exam consists of a discussion of the results obtained in the project and its goal is to check the understanding of the concepts introduced in the lectures and the ability of being able to use them in concrete situations
Teaching tools
The lectures utilize overhead slides projected from a laptop computer together with a white board, scientific papers made available to student, etc. The material presented during lectures will be made available in electronic format for downloading from the Course web site.
Office hours
See the website of Jocelyne Elias
See the website of Davide Rossi