Corso di Informatica 1 (IN110) Tutorato n. 10

Documenti analoghi
Corso di Informatica 1 (IN1) Tutorato n. 11

Esercizi su liste e grafi

Università degli Studi Roma Tre Dipartimento di Matematica e Fisica Corso di Laurea in Matematica

Università degli Studi Roma Tre Dipartimento di Matematica e Fisica Corso di Laurea in Matematica

Corso di Informatica 1 Esercitazione n. 7

Calcolatori Elettronici Lezione 2 8/10/2012. Emiliano Casalicchio

Corso di O)mizzazione Combinatoria (IN440) - Prof. Marco Liverani a.a. 2013/2014. Libreria grafi.c

Esercizi d esame. Raccolta di esercizi degli esami del corso di Informatica Generale 1. Marco Liverani

Corso di Informatica 1 (IN110) Tutorato n. 3

Corso di Informatica 1 Esercitazione n. 2

Corso di Informatica 1 (IN110) Tutorato n. 4

Esercizi d esame. Raccolta di esercizi degli esami del corso di Informatica Generale 1. Marco Liverani

Corso di Informatica 1 Esercitazione n. 4

Prima prova di esonero 5 novembre 2007

Prima prova di esonero 2 novembre 2015

(*lista == NULL (*lista)->info >= elem) accede al campo next di *lista solo se *lista non e' NULL. */ #include <stdio.h> #include <stdlib.

STRUCT - ESERCIZIO 1

Fondamenti di Informatica T1. Lab 04 Array. Lab06 1

Esercizio 1 - Soluzione (array)

Laboratorio di Programmazione

Esercizio 1 Soluzione

Fondamenti di Informatica: Ingegneria Meccanica Prova scritta del 12 luglio 2008

/* programma per costruire una partizione del grafo in foreste disgiunte */ #include <stdio.h> #include <stdlib.h>

Introduzione ai Grafi: Implementazione e operazioni di base

Fondamenti di Informatica e Laboratorio T-AB Ingegneria Elettronica e Telecomunicazioni. Lab 05 Array. Lab06 1

IMPLEMENTAZIONE CONCATENATE DELLE LISTE

Politecnico di Milano - Dipartimento di Elettronica e informazione Prof. Mauro Negri

Università degli Studi di Verona. Esercizi. Gennaio Sergio Marin Vargas. Dipartimento di Biotecnologie

acquisizione numero elementi del primo insieme e del secondo insieme, finché elprimoinsieme oppure elsecondoinsieme > EL_INS

Esercizio 1: calcolo del massimo di una sequenza (versione 1)

Il linguaggio C Strutture

Esercitazione 6. Corso di Fondamenti di Informatica

Esercizio 1: Puntatori impiegati che sono manager

Laboratorio di Algoritmi e Strutture Dati

IEIM Esercitazione II Elementi di programmazione C. Alessandro A. Nacci -

Esercitazione 2. Corso di Fondamenti di Informatica

Lab 04 Istruzioni, cicli e array"

il precedente programma dichiara un vettore di interi di dimensione 10 e successivamente inserisce il valore 4 nel secondo elemento del vettore.

Informatica 1. Prova di recupero 21 Settembre 2001

Esercizio 1 - cicli. Esercizio 1 cicli - Soluzione

Esercitazione 7. Tutor: Ing. Diego Rughetti. Anno Accademico 2007/2008

Linguaggi di programmazione + laboratorio a.a. 2012/2013

giapresente( ) leggi( ) char * strstr(char * cs, char * ct) NULL

Il linguaggio C Strutture

fondamenti di informatica 2 programmazione in C++ Riccardo Galletti - tratto da

Linguaggio C: Array Valeria Cardellini

Informatica B

Fondamenti di Informatica T-1 Modulo 2

Complessità algoritmi su strutture dati (riassunto)

IL CONCETTO DI LISTA!

Prova Scritta del 20/09/10

Informatica I Facoltà di Ingegneria

IEIM Esercitazione 1 Primi passi con la programmazione" Alessandro A. Nacci -

Ogni parte non cancellata a penna sarà considerata parte integrante della soluzione.

il precedente programma dichiara un vettore di interi di dimensione 10 e successivamente inserisce il valore 4 nel secondo elemento del vettore.

Esercizio 1: media di numeri reali (uso funzioni e struct)

Lezione 8 Liste. Rossano Venturini. Pagina web del corso.

Strutture dati dinamiche in C (II)

Lezione 10 Liste. Rossano Venturini. Pagina web del corso.

Alcuni esercizi. 1. Valutazione in cortocircuito 2. If e if innestati 3. Switch 4. Cicli

Laboratorio di Algoritmi e Strutture Dati

ESERCIZIO: SHIFT ARRAY (1)

Algoritmi e Strutture di Dati A.A Esempio di prova scritta del 19 gennaio 2018 D.M CFU Libri e appunti chiusi Tempo = 2:00h

In una coda gli inserimenti si fanno alla fine e le cancellazioni all inizio! First In First Out

Esercitazione 6. Array

Università degli Studi di Brescia. Vettori di variabili. ! Sono variabili aggregate in grado di memorizzare una collezione (organizzata) di oggetti

Esercitazione 11. Liste semplici

Esercitazioni di Prog. II (funzioni su insiemi) Chiara Petrioli

Input / Output, Espressioni Condizionali e Cicli

# include<stdio.h> int main() { // Dichiarazioni int n; int i;

Esercizio 1 File: ordinamento di un archivio di studenti (file binario)

Cognome Domanda Nome Punteggio max

Esercitazione 7. Soluzione:

Esercizio 1: calcolo insieme intersezione

1: #include <stdio.h> 2: #include <stdlib.h> 3: 4: #define MAXDIM 10 5: 6: int main(int argc, char *argv[]) 7: { 8: int numrighe1, numcolonne1,

Introduzione al C. Lez. 2 Funzioni e Puntatori

Esercizio 1. Esercizio 1 - Soluzione

Fondamenti di Informatica 1 - Compito A

Programmazione I. Sessione giugno - luglio (Primo appello) Prova scritta 10 giugno Classe 1 (Matricole congrue a 0 modulo 3)

Complessità algoritmi su strutture dati

Strutture di Controllo Iterative: Istruzioni While e Do

Programmazione I - Laboratorio

Tutorato Programmazione 1 Modulo 2

Politecnico di Milano - Dipartimento di Elettronica e informazione Prof. Mauro Negri

Sistemi operativi A, Unix+C, 26/09/2017. Nome: Cognome: Matricola:

7.1 Progettare un algoritmo per costruire ciclo euleriano di un grafo non orientato.

Array. Maurizio Palesi Salvatore Serrano. In C si possono definire tipi strutturati Vi sono due costruttori fondamentali

Università degli Studi di Verona. Esercizi (seconda parte) Gennaio Sergio Marin Vargas. Dipartimento di Biotecnologie

Corso di Laboratorio di Sistemi Operativi A.A

ADT LISTA: altre operazioni non primitive ADT LISTA COSTRUZIONE ADT LISTA COSTRUZIONE ADT LISTA (2)

L albero e un tipo astratto di dati usato per rappresentare relazioni gerarchiche.

Fondamenti di Informatica II

Lab 14 Algoritmi di ordinamento

Appunti del corso di Informatica 1 (IN110 Fondamenti) 7 Grafi e alberi: introduzione

3 Costrutti while, for e switch

Liste concatenate. Violetta Lonati

Transcript:

Corso di Informatica 1 (IN110) Tutorato n. 10 Marco Liverani Esercizio n. 1 Letto un grafo non orientato G = (V,E) e letta una lista di vertici di V, L = {v 1,..., v k }, stabilire se il sottografo G indotto da L è completo. Un sottografo è completo se i suoi vertici sono adiacenti a tutti gli altri vertici del sottografo. Il grafo G è il sottografo indotto di G mediante l insieme di vertici L V (G) se gli spigoli di G sono tutti e soli gli spigoli di G aventi per estremi vertici in L. Codifica in linguaggio C 1 #include <stdlib.h> 2 #include <stdio.h> 3 #define MAX 100 4 5 struct nodo { 6 int info; 7 struct nodo *next; 8 }; 9 10 struct nodo *leggi_lista(void) { 11 struct nodo *p, *primo = NULL; 12 int i, n; 13 printf(" inserisci il numero di elementi: "); 14 scanf("%d", &n); 15 printf(" inserisci %d elementi: ", n); 16 for (i=0; i<n; i++) { 17 p = malloc(sizeof(struct nodo)); 18 p->next = primo; 19 scanf("%d", &p->info); 20 primo = p; 21 } 22 return(primo); 23 } 24 25 void stampa_lista(struct nodo *p) { 26 while (p!= NULL) { 27 printf("%d --> ", p->info); 28 p = p->next; Università degli Studi Roma Tre, Corso di Laurea in Matematica, Corso di Informatica Generale 1 (IN110); liverani@mat.uniroma3.it sito web del corso http://www.mat.uniroma3.it/users/liverani/in110/ e-mail 1

29 } 30 printf("null\n"); 31 return; 32 } 33 34 int leggi_grafo(struct nodo *G[]) { 35 int i, n; 36 printf("inserisci il numero di vertici del grafo: "); 37 scanf("%d", &n); 38 for (i=0; i<n; i++) { 39 printf("lista di adiacenza del vertice %d:\n", i); 40 G[i] = leggi_lista(); 41 } 42 return(n); 43 } 44 45 void stampa_grafo(struct nodo *G[], int n) { 46 int i; 47 printf("liste di adiacenza dei vertici del grafo:\n"); 48 for (i=0; i<n; i++) { 49 printf(" vertici adiacenti a %d: ", i); 50 stampa_lista(g[i]); 51 } 52 return; 53 } 54 55 int adiacente(int i, int j, struct nodo *G[]) { 56 struct nodo *p; 57 p = G[i]; 58 while (p!= NULL && p->info!= j) { 59 p = p->next; 60 } 61 if (p == NULL) 62 return(0); 63 else 64 return(1); 65 } 66 67 int completo(struct nodo *G[], struct nodo *L, int n) { 68 struct nodo *p, *q; 69 int flag=1; 70 p = L; 71 while (p!= NULL && flag==1) { 72 q = L; 73 while (q!= NULL && flag==1) { 74 if (q->info!= p->info &&!adiacente(p->info, q->info, G)) 75 flag = 0; 76 q = q->next; 77 } 78 p = p->next; 79 } 80 return(flag); 81 } 82 2

83 int main(void) { 84 struct nodo *G[MAX], *L; 85 int n; 86 n = leggi_grafo(g); 87 stampa_grafo(g, n); 88 L = leggi_lista(); 89 if (completo(g, L, n)) { 90 printf("il sottografo di G indotto da L e completo.\n"); 91 } else { 92 printf("il sottografo di G indotto da L NON e completo.\n"); 93 } 94 return(0); 95 } 3

Esercizio n. 2 Leggere in input una sequenza di numeri interi ordinati in ordine crescente. Dopo aver memorizzato la sequenza in una lista, inserire nella posizione corretta all interno della lista, tutti i numeri mancanti. Stampare in output la lista. Non devono essere usate altre liste o array di appoggio. Esempio Supponiamo che sia fornita in input la sequenza 4,7,8,9,15,17,21. Dopo aver memorizzato gli elementi nella lista 4 7 8... 21, vengono inseriti i numeri mancanti, ottenendo la lista composta dagli elementi 4 5 6 7 8... 19 20 21. Codifica in linguaggio C 1 #include <stdlib.h> 2 #include <stdio.h> 3 4 struct nodo { 5 int info; 6 struct nodo *next; 7 }; 8 9 struct nodo *leggi_lista(void) { 10 struct nodo *p, *primo = NULL; 11 int i, n; 12 printf("numero di elementi: "); 13 scanf("%d", &n); 14 printf("inserisci %d numeri interi in ordine crescente: ", n); 15 for (i=0; i<n; i++) { 16 p = malloc(sizeof(struct nodo)); 17 scanf("%d", &p->info); 18 p->next = primo; 19 primo = p; 20 } 21 return(primo); 22 } 23 24 void completa_lista(struct nodo *p) { 25 struct nodo *q; 26 while (p->next!= NULL) { 27 if (p->info > p->next->info + 1) { 28 q = malloc(sizeof(struct nodo)); 29 q->info = p->next->info + 1; 30 q->next = p->next; 31 p->next = q; 32 } else { 33 p = p->next; 34 } 35 } 36 return; 37 } 38 39 void stampa_lista(struct nodo *p) { 40 while (p!= NULL) { 41 printf("%d --> ", p->info); 4

42 p = p->next; 43 } 44 printf("null\n"); 45 return; 46 } 47 48 int main(void) { 49 struct nodo *primo; 50 primo = leggi_lista(); 51 completa_lista(primo); 52 stampa_lista(primo); 53 return(0); 54 } 5

Esercizio n. 3 Letto un grafo non orientato G = (V,E) rappresentarlo con liste di adiacenza. Letta in input un sottoinsieme di vertici di V, rappresentarla mediante una lista L (L V ). Verificare se L è una copertura di vertici di G, ossia se per ogni (u, v) E risulta u L o v L (o entrambi). Esempio Consideriamo il grafo G = (V,E) rappresentato in figura, in cui l insieme dei vertici è V = {0,1,2,3,4} e l insieme degli spigoli è E = {(0,1),(0,2),(1,2),(2,3),(2,4),(3,4)}: 1 0 2 4 3 La lista L = {1,2,3} è una copertura di G, mentre L = {0,1,3} non è una copertura, infatti gli estremi dello spigolo (4,2) non appartengono a L. Codifica in linguaggio C 1 #include <stdlib.h> 2 #include <stdio.h> 3 #define MAX 20 4 5 struct nodo { 6 int info; 7 struct nodo *next; 8 }; 9 10 struct nodo *leggi_lista(void) { 11 int i, n; 12 struct nodo *p, *primo=null; 13 printf("numero di elementi: "); 14 scanf("%d", &n); 15 printf("inserisci %d elementi: ", n); 16 for (i=0; i<n; i++) { 17 p = malloc(sizeof(struct nodo)); 18 scanf("%d", &p->info); 19 p->next = primo; 20 primo = p; 21 } 22 return(primo); 23 } 24 25 void stampa_lista(struct nodo *p) { 26 while (p!= NULL) { 27 printf("%d --> ", p->info); 28 p = p->next; 29 } 30 printf("null\n"); 6

31 return; 32 } 33 34 int leggi_grafo(struct nodo *v[]) { 35 int i, n; 36 printf("numero di vertici del grafo: "); 37 scanf("%d", &n); 38 for (i=0; i<n; i++) { 39 printf("lista di adiacenza del vertice %d\n", i); 40 v[i] = leggi_lista(); 41 } 42 return(n); 43 } 44 45 void stampa_grafo(struct nodo *v[], int n) { 46 int i; 47 printf("liste di adiacenza del grafo\n"); 48 for (i=0; i<n; i++) { 49 printf("%d: ", i); 50 stampa_lista(v[i]); 51 } 52 return; 53 } 54 55 int appartiene(int i, struct nodo *t) { 56 int trovato = 0; 57 while (t!=null &&!trovato) { 58 if (t->info == i) 59 trovato = 1; 60 t = t->next; 61 } 62 return(trovato); 63 } 64 65 int copertura(struct nodo *v[], int n, struct nodo *p) { 66 struct nodo *q; 67 int i, flag=1; 68 for (i=0; i<n && flag; i++) { 69 flag = 0; 70 if (!appartiene(i, p)) { 71 q = v[i]; 72 flag = 1; 73 while (flag && q!=null) { 74 if (!appartiene(q->info, p)) 75 flag = 0; 76 q = q->next; 77 } 78 } else { 79 flag = 1; 80 } 81 } 82 return(flag); 83 } 84 7

85 int main(void) { 86 struct nodo *v[max], *p; 87 int n; 88 n = leggi_grafo(v); 89 p = leggi_lista(); 90 if (copertura(v, n, p)) 91 printf("la lista e una copertura del grafo.\n"); 92 else 93 printf("la lista non e una copertura del grafo.\n"); 94 return(0); 95 } 8

Esercizio n. 4 Letto in input un grafo non orientato G = (V,E) con n vertici (V = {0,1,2,...,n 1}) e una lista di numeri interi compresi tra 0 e n 1, verificare se la lista rappresenta un cammino sul grafo. Codifica in linguaggio C 1 #include <stdlib.h> 2 #include <stdio.h> 3 #define MAX 100 4 5 struct nodo { 6 int info; 7 struct nodo *next; 8 }; 9 10 struct nodo *leggi_lista(void) { 11 struct nodo *p, *primo; 12 int i, n; 13 primo = NULL; 14 printf("numero di elementi: "); 15 scanf("%d", &n); 16 printf("inserisci %d vertici: ", n); 17 for (i=0; i<n; i++) { 18 p = malloc(sizeof(struct nodo)); 19 scanf("%d", &p->info); 20 p->next = primo; 21 primo = p; 22 } 23 return(primo); 24 } 25 26 void stampa_lista(struct nodo *p) { 27 while (p!= NULL) { 28 printf("%d ---> ", p->info); 29 p = p->next; 30 } 31 printf("null\n"); 32 return; 33 } 34 35 int leggi_grafo(struct nodo *L[]) { 36 int i, n; 37 printf("numero di vertici del grafo: "); 38 scanf("%d", &n); 39 for (i=0; i<n; i++) { 40 printf("lista dei vertici adiacenti al vertice %d.\n", i); 41 L[i] = leggi_lista(); 42 } 43 return(n); 44 } 45 46 9

47 void stampa_grafo(struct nodo *L[], int n) { 48 int i; 49 printf("liste di adiacenza dei vertici del grafo:\n"); 50 for (i=0; i<n; i++) { 51 printf("%2d: ", i); 52 stampa_lista(l[i]); 53 } 54 printf("\n"); 55 return; 56 } 57 58 int adiacente(struct nodo *G[], int u, int v) { 59 struct nodo *p; 60 p = G[u]; 61 while (p!= NULL && p->info!= v) { 62 p = p->next; 63 } 64 if (p == NULL) 65 return(0); 66 else 67 return(1); 68 } 69 70 int main(void) { 71 struct nodo *G[100], *primo, *p; 72 int n, ok=1; 73 n = leggi_grafo(g); 74 stampa_grafo(g, n); 75 printf("inserimento della lista di vertici da verificare\n"); 76 primo = leggi_lista(); 77 p = primo; 78 while (ok && p->next!= NULL) { 79 if (!adiacente(g, p->info, p->next->info)) 80 ok = 0; 81 p = p->next; 82 } 83 if (ok) 84 printf("la lista costituisce un cammino sul grafo.\n"); 85 else 86 printf("la lista non rappresenta un cammino sul grafo.\n"); 87 return(0); 88 } 10