Strumenti Utente

Strumenti Sito


informatica:sol:laboratorio19:esercitazionib:esercitazione4

Esercitazione 4

Esercizio 1:

Scrivere un programma che prende in ingresso un intero 'N' ('N' e' piccolo, es. <=512), alloca in memoria una matrice di NxN elementi float in modo che siano contigui in memoria. Inizializzare tale matrice (chiamata ad esempio M1) in modo arbitrario (ad esempio M1(i,j) = (i+j)/2.0). Fare quindi il salvataggio in un file della matrice sia in formato binario che in formato testuale in modo da ottenere due file separati 'mat_dump.dat' per il formato binario e 'mat_dump.txt' per quello testuale. Chiudere i file creati.

Scrivere un secondo programma (oppure estendere quello precedente) che prende in ingresso i nomi dei due file creati in precedenza e l'intero 'N', legge la matrice sia dal file 'mat_dump.dat' che dal file 'mat_dump.txt' memorizzandone il contenuto in due matrici distinte. Al termine dell'operazione di lettura, effettua il confronto delle due matrici con la funzione 'confronta' che deve essere implementata in modo “generico” cioe' deve prendere come argomenti un puntatore a funzione con tipo opportuno, i puntatori alle due matrici da confrontare e la size delle matrici. Il programma deve stampare l'esito del confronto. Testare il programma passando alla funzione 'confronta' la funzione di libreria memcmp (man 3 'memcmp').

Notare la differenza di size tra 'mat_dump.dat' e 'mat_dump.txt'.

Esercizio 2:

Scrivere un Makefile minimale per compilare l'esercizio precedente. Utilizzare il compilatore g++ ed i flags -g -O3 -Wall. Il Makefile deve avere anche il target “phony” clean.

Esercizio 3:

Scrivere un programma C che dato un file testuale come argomento, inserisca tutte le parole del file in una lista ordinando le parole alfabeticamente. Ogni linea del file testuale puo' contenere piu' parole. Implementare la seguente interfaccia:

list_t *createList();                         // crea una lista vuota   
int     destroyList(list_t *L);               // libera tutta la memoria allocata dalla lista
int     insertList(list_t *L, const char *);  // inserisce una parola nella lista
void    printList(list_t *L);                 // stampa tutta la lista

Fornire i metodi di creazione e gestione della lista in una libreria statica (libList.a). Scrivere il Makefile per creare la libreria e generare l'eseguibile.

Esercizio 4:

Scrivere un programma che implementa una versione semplificata del comando Unix wc limitatamente alle opzioni -l e -w (man 1 wc). Usare getopt per il parsing degli argomenti (man 3 getopt). Se non vengono passate opzioni, il programma stampa sia il numero di linee che il numero di parole del/dei file i cui nomi sono passati come argomento (mywc [-l -w] file1 [file2 file3 ….]).

informatica/sol/laboratorio19/esercitazionib/esercitazione4.txt · Ultima modifica: 13/03/2019 alle 05:46 (5 anni fa) da Massimo Torquati