Algoritmi e Strutture Dati

Novità 2017/18

Per gli stu­den­ti di Informatica, l’anno pros­si­mo il cor­so si svol­ge­rà in for­ma annua­le: un uni­co cor­so di 12 cre­di­ti, svol­to in entram­bi i seme­stri.

Sommario

Il cor­so ha lo sco­po di pre­sen­ta­re i con­cet­ti fon­da­men­ta­li dell’algoritmica, ovve­ro quel­la bran­ca dell’informatica che si occu­pa del­la defi­ni­zio­ne e la pro­get­ta­zio­ne degli algo­rit­mi, l’analisi del­la loro cor­ret­tez­za e del­la loro effi­cien­za, la dimo­stra­zio­ne del­le loro limi­ta­zio­ni e com­ples­si­tà, e lo stu­dio dei dati da essi ela­bo­ra­ti.

Verranno pre­sen­ta­ti algo­rit­mi per risol­ve­re alcu­ni pro­ble­mi fon­da­men­ta­li (qua­li ad esem­pio l’ordinamento), tec­ni­che per l’analisi degli algo­rit­mi (nota­zio­ne asin­to­ti­ca e ricor­ren­ze),  strut­tu­re dati ele­men­ta­ri (qua­li liste, pile, code), strut­tu­re dati non linea­ri (albe­ri e gra­fi) e gli algo­rit­mi ad esse col­le­ga­ti, strut­tu­re dati avan­za­te (albe­ri red-black, heap, tabel­le hash, etc.). Particolare enfa­si ver­rà dedi­ca­ta alle meto­do­lo­gie di pro­get­ta­zio­ne di algo­rit­mi (divi­de et impe­ra, pro­gram­ma­zio­ne dina­mi­ca, meto­do gree­dy, back­trac­king, ricer­ca loca­le).

Prerequisiti

Si assu­me che lo stu­den­te cono­sca i con­cet­ti pre­sen­ta­ti nei cor­si di Analisi, Geometria ed Algebra Lineare, Fondamenti Matematici per l’Informatica, Programmazione 1, Linguaggi di Programmazione più qual­che ele­men­to di cal­co­lo del­le pro­ba­bi­li­tà.

Per gli stu­den­ti del cor­so di lau­rea in Matematica, le mag­gio­ri cono­scen­ze nel cam­po dell’Analisi Matematica com­pen­sa­no le mino­ri cono­scen­ze nel cam­po del­la Programmazione, ren­den­do l’esame affron­ta­bi­le sen­za pro­ble­mi da gran par­te degli stu­den­ti di Matematica.