Algoritmi e Strutture Dati

Novità 2017/18

  • Per gli stu­den­ti del Corso di Laurea in Informatica, il cor­so diven­ta annua­le:  un uni­co cor­so di 12 cre­di­ti, che ini­zia a set­tem­bre a fini­sce a mag­gio (145004).
  • Per gli stu­den­ti del Corso di Laurea in Matematica, il cor­so si spez­za in due uni­tà didat­ti­che (145946, 145947), una per seme­stre, sele­zio­na­bi­li come cor­si affi­ni. Se sie­te anco­ra inde­ci­si, ecco due righe sul per­ché uno stu­den­te di Matematica dovreb­be stu­dia­re Algoritmi e Strutture Dati.
  • Per gli stu­den­ti del Corso di Laurea in Ingegneria dell’Informazione e Organizzazione d’Impresa, nel mani­fe­sto tro­va­te  il pri­mo modu­lo sot­to il nome di “Fondamenti di algo­rit­mi e strut­tu­re Dati” (145929), sele­zio­na­bi­le come cor­so a scel­ta. Se sie­te anco­ra inde­ci­si, ecco due righe sul per­ché uno stu­den­te di Inf.Org. dovreb­be stu­dia­re Algoritmi e Strutture Dati.

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 elaborati.

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 locale).

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, più qual­che ele­men­to di cal­co­lo del­le probabilità.

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 problemi.