Laboratorio di programmazione
|
|
|
- Cosimo Mura
- 7 anni fa
- Просмотров:
Транскрипт
1 Laboratorio di programmazione Lezione VI Tatiana Zolo 1
2 Dichiarazione (forma generale): LE STRUCT struct nome_struttura { tipo var1; tipo var2;... tipo vark; } variabili_struttura; (soltanto una variabile struttura nome_struttura non necessario). Ora posso creare delle variabili di tipo nome_struttura: nome_struttura var_struttura; E STRUCT 2
3 Dichiarazione (forma generale): LE STRUCT struct nome_struttura { tipo var1; tipo var2;... tipo vark; } variabili_struttura; (soltanto una variabile struttura nome_struttura non necessario). Ora posso creare delle variabili di tipo nome_struttura: nome_struttura var_struttura; Accesso ai membri: tramite l operatore punto. nome_struttura.var1 =...; tipo t = nome_struttura.var2; E STRUCT 2-A
4 LE STRUCT Assegnamento di strutture: solo se sono dello stesso tipo. E STRUCT 3
5 LE STRUCT Assegnamento di strutture: solo se sono dello stesso tipo. Array di struct: si definisce una struttura e poi si dichiara un array di quel tipo. Esempio: struct studenti { char nome[50]; char cognome[50]; int anno_immatricolazione; }; studenti elenco_studenti[100]; Per accedere ad una struttura specifica indicizzare il nome della struttura: cout << elenco_studenti[2].cognome stampa il cognome memorizzato nella variabile membro cognome dello studente i cui dati sono nella parte sempre da 0!). struttura dell array (l indice dell array E STRUCT 3-A
6 LE FUNZIONI Ogni funzione è composta da 4 parti (che insieme costituiscono la definizione della funzione): 1. tipo di ritorno; 2. nome della funzione; 3. lista dei parametri; 4. corpo della funzione. Le prime tre parti insieme rappresentano il prototipo della funzione o la dichiarazione della funzione. Invocazione funzione f() controllo del programma ad f() e sospensione dell esecuzione della funzione attiva. Fine esecuzione di f() (ultima istruzione oppure istruzione di ritorno) la funzione sospesa riprende l esecuzione. E FUNZIONI 4
7 PROTOTIPO DI UNA FUNZIONE 1. Tipo di ritorno: può essere tipo predefinito (es.int); tipo composto (es.double*, cioè puntatori); tipo definito dall utente (es. struct, classi); void, cioè la funzione non restituisce alcun valore. Non si possono usare come tipi di ritorno un tipo funzione oppure un tipo array predefinito. C++ standard: il tipo di ritorno non può essere omesso tempo di compilazione. errore a ROTOTIPO DI UNA FUNZIONE 5
8 PROTOTIPO DI UNA FUNZIONE 1. Tipo di ritorno: può essere tipo predefinito (es.int); tipo composto (es.double*, cioè puntatori); tipo definito dall utente (es. struct, classi); void, cioè la funzione non restituisce alcun valore. Non si possono usare come tipi di ritorno un tipo funzione oppure un tipo array predefinito. C++ standard: il tipo di ritorno non può essere omesso tempo di compilazione. errore a 3. Lista dei parametri: in una definizione di funzione un nome di parametro consente di accedere al parametro nel corpo della funzione; in una dichiarazione di funzione il nome del parametro non è necessario (se c è può essere diverso da quello della def. di funz.). Controllo di tipo dei parametri al momento della compilazione. ROTOTIPO DI UNA FUNZIONE 5-A
9 Passaggio per valore: PASSAGGIO DEGLI ARGOMENTI int nome_funz(int n) { n = n + 1; return n; } Chiamata: n = 0; m = nome_funz(n); Risultato:, Passaggio per riferimento: int nome_funz(int& n) { n = n + 1; return n; } Chiamata: n = 0; m = nome_funz(n); Risultato:, ASSAGGIO DEGLI ARGOMENTI 6
10 PARAMETRI ARRAY In C++ un array non è mai passato per valore, ma come un puntatore al suo primo elemento. Conseguenze: le modifiche sono effettuate sull array stesso e non su una copia locale; la dimensione di un array non fa parte del suo tipo parametro. es.array_candidati.cc. ARAMETRI ARRAY 7
11 ESERCIZI 1. Struct: creare una struct "persona" (il nome scieglietelo pure voi, ma sensato) con due membri: nome e numero di telefono. Scrivere un programma che, una volta riempite con i dati necessari tre struct "persona", dia le seguenti 3 possibilita : 1. conoscere il nome a partire da un numero di telefono; 2. conoscere il numero di telefono a partire da un nome; 3. uscire dal programma. (nome_telefono.cc). 2. Array di struct e funzioni: leggere n struct di persone ( n inserito dall utente) con due campi, nome ed eta, e restituire il nome della piu giovane o di una delle piu giovani. Utilizzare una funzione per la lettura dei dati delle struct e una che restituisca l indice della persona selezionata. (piu_giovane_array.cc). SERCIZI 8
12 ESERCIZI 3. Array di struct e funzioni: crea un array di struct "studente" (cognome, array contenente i voti degli esami). Presenta all utente un menu con varie possibilita : media (in trentesimi); media (in 110); voto piu alto; voto piu basso; fine programma. Realizza ciascuna operazione con una funzione. Possibili estensioni dell esercizio: altre operazioni possibili sono vedere quante volte e stato preso un certo voto; fare un grafico dell andamento dei voti (es. con una matrice di caratteri). Ampliare la struct "studente" inserendo altri dati: nome materia, data esame, eventuale lode, ecc. (voti_esami.cc). SERCIZI 9
Laboratorio di programmazione
Laboratorio di programmazione Lezione VI Tatiana Zolo [email protected] 1 LE STRUCT Tipo definito dall utente i cui elementi possono essere eterogenei (di tipo diverso). Introduce un nuovo tipo di
Laboratorio di programmazione
Laboratorio di programmazione Lezione II Tatiana Zolo [email protected] 1 IL PROGRAMMA C++ Istruzioni (espressioni terminate da ; ) istruzioni di dichiarazione (es. int x = 0;); istruzioni di assegnamento
Le strutture /1. struct temp {char titolo[200]; char autore[100]; int pagine; } ; typedef struct temp libro;
Le strutture /1 Le strutture rappresentano un tipo di variabile che, diversamente dagli array, consente di gestire in modo compatto, mediante un'unico identificatore, un insieme di valori che non possiedano
Il linguaggio C. Puntatori e dintorni
Il linguaggio C Puntatori e dintorni 1 Puntatori : idea di base In C è possibile conoscere e denotare l indirizzo della cella di memoria in cui è memorizzata una variabile (il puntatore) es : int a = 50;
Funzioni in C. Funzioni. Strategie di programmazione. Funzioni in C. Come riusare il codice? (2/3) Come riusare il codice? (1/3)
Funzioni Il concetto di funzione Parametri formali e attuali Il valore di ritorno Definizione e chiamata di funzioni Passaggio dei parametri Corpo della funzione 2 Strategie di programmazione Riuso di
Esercizi di riepilogo (Fondamenti di Informatica 1 Walter Didimo)
Esercizi di riepilogo (Fondamenti di Informatica 1 Walter Didimo) Selezione di prove di esame al calcolatore Esercizio 1 (esame del 13/01/2006) La classe Matrice definisce oggetti che rappresentano matrici
Esercizi. Filtraggio
Politecnico di Milano Esercizi Preparazione alla prima prova intermedia Filtraggio L utente inserisce un array di numeri reali non negativi (un numero negativo indica la fine della fase di inserimento)
Linguaggio C: puntatori
Dipartimento di Elettronica ed Informazione Politecnico di Milano Informatica A - GES Prof. Plebani A.A. 2006/2007 Linguaggio C: puntatori La presente dispensa e da utilizzarsi ai soli fini didattici previa
Laboratorio di programmazione
Laboratorio di programmazione Lezione VIII Tatiana Zolo [email protected] 1 PROGRAMMAZIONE A OGGETTI Quando si programma a oggetti si scompone il problema in sottogruppi di parti collegate che tengono
Il paradigma OO e le Classi
Oggetti e Classi (CAP 10) Alberto Garfagnini Università degli studi di Padova 1 Dicembre 2009 Il paradigma OO e le Classi La programmazione ad Oggetti () è una filosofia di programmazione che si basa sui
Informatica A. Istruzioni
Informatica A Cognome Nome Matricola o Codice studente Istruzioni Non separate questi fogli. Scrivete la soluzione solo sui fogli distribuiti, utilizzando il retro delle pagine in caso di necessità. Cancellate
Aritmetica dei puntatori
Aritmetica dei puntatori Marco Alberti Programmazione e Laboratorio, A.A. 2016-2017 Dipartimento di Matematica e Informatica - Università di Ferrara Ultima modifica: 7 dicembre 2016 sizeof L operatore
Tipi di dati strutturati e Linguaggio C. Record o strutture Il costruttore struct in C
Tipi di dati strutturati e Linguaggio C Record o strutture Il costruttore struct in C Dati strutturati Record Un record o struttura è una struttura dati ottenuta aggregando elementi di tipo diverso che
Lezione 9: Puntatori a funzioni. Tipi enumerativi e orientati ai bit
Lezione 9: Puntatori a funzioni. Tipi enumerativi e orientati ai bit Vittorio Scarano Laboratorio di Informatica I Corso di Laurea in Informatica Università degli Studi di Salerno Struttura della lezione
Dati aggregati. Violetta Lonati
Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica - in breve: Definizione di tipi Array Stringhe Strutture
Linguaggio C: PUNTATORI
Linguaggio C: PUNTATORI I puntatori sono una delle più importanti caratteristiche del linguaggio C. Permettono di lavorare a basso livello, mantenendo flessibilità e praticità. Il C utilizza molto i puntatori
Fondamenti di Informatica - 1. Prof. B.Buttarazzi A.A. 2011/2012
Fondamenti di Informatica - 1 Prof. B.Buttarazzi A.A. 2011/2012 Sommario Operatore? Tipo di dato: struct La ricorsione Funzioni ricorsive Esercizi proposti 26/04/2012 2 Operatore? L'operatore? può essere
Il linguaggio C. Puntatori e dintorni
Il linguaggio C Puntatori e dintorni 1 Puntatori : idea di base In C è possibile conoscere e denotare l indirizzo della cella di memoria in cui è memorizzata una variabile (il puntatore) es : int a = 50;
COMPITO DI LABORATORIO DI PROGRAMMAZIONE Dicembre Alcune Soluzioni
COMPITO DI LABORATORIO DI PROGRAMMAZIONE 2001-2002 10 Dicembre 2001 Alcune Soluzioni ESERCIZIO 1. Si consideri il seguente frammento di codice in linguaggio Java: int[][] a = new int[n][n]; for (int i
Esercizio 1: funzione con valore di ritorno di tipo puntatore
Esercitazione Fondamenti di Informatica B Corso di Laurea in Ingegneria Meccanica 7 Esercitazione: 14 dicembre 2005 Esercizi su ricorsione, manipolazione stringhe, strutture dinamiche Problema: Esercizio
