Array multidimensionali e stringhe

Похожие документы
C: panoramica. Violetta Lonati

Non ci sono vincoli sul tipo degli elementi di un vettore Possiamo dunque avere anche vettori di

Linguaggio C: Array Valeria Cardellini

Esercitazione di Reti degli elaboratori

Cicli annidati ed Array multidimensionali

Lezione 8: Stringhe ed array multidimensionali

I tipi strutturati e i record in C++

I puntatori. Un puntatore è una variabile che contiene l indirizzo di un altra variabile. puntatore

Array Tipi di dato semplici e strutturati strutturati array elementi omogenei numero d ordine indice lunghezza dimensione

Introduzione a Matlab

Primi passi col linguaggio C

Gli Array. Dichiarazione di un array

Problema. Vettori e matrici. Vettori. Vettori

Programmazione Procedurale in Linguaggio C++

Allocazione dinamica della memoria

Strutture dati e loro organizzazione. Gabriella Trucco

PROGRAMMAZIONE AVANZATA JAVA E C

Unità Didattica 4 Linguaggio C. Vettori. Puntatori. Funzioni: passaggio di parametri per indirizzo.

9 - Array. Programmazione e analisi di dati Modulo A: Programmazione in Java. Paolo Milazzo

Esercitazione 6. Array

Le basi del linguaggio Java

Introduzione al linguaggio C Puntatori

Programmazione I - Laboratorio

Esercizi. La funzione swapint() primo tentativo

Lezione 6 programmazione in Java

Introduzione al linguaggio C Funzioni

Stringhe di caratteri

Funzioni in C. Funzioni. Strategie di programmazione. Funzioni in C. Come riusare il codice? (2/3) Come riusare il codice? (1/3)

Транскрипт:

Andrea Marin Università Ca Foscari Venezia Laurea in Informatica Corso di Programmazione part-time a.a. 2011/2012

Array uni-dimensionali (richiami) Dichiarazione: int vet[100]; float x[50]; Gli elementi sono indicizzati da 0 a N 1 dove N è la dimensione dell array (N = 100 nei precedenti casi) vett[i] denota l elemento in posizione i del vettore i deve essere un numero intero compreso tra 0 e N 1 x[i] è una variabile di tipo float vet[i] è uunidimensionalena variabile di tipo int Negli array multi-dimensionali possiamo usare più indici per indicare un elemento

Esempio Si vogliono memorizzare i livelli di inquinamento in una città mediante delle sonde Nella città sono presente 100 sonde rilevatrici Ciascuna sonda rileva il livello di inquinamento ogni 15 minuti Come memorizzare le rilevazioni di una giornata? Una giornata ha 24 ore, quindi genera 24 4 = 96 rilevazioni Possiamo usare una tabella di 100 righe (una per ogni sonda) e 96 colonne (un per ogni rilevazione) Ci sono in totale 96 100 = 9600 dati misurati Per accedere ad una particolare rilevazione bisogna specificare L indice i della sonda 0 i 99 L indice j della rilevazione desiderata 0 j 95

Dichiarazione in C #define NSONDE 100 #define NRILIEVI 96 f l o a t l i v e l l o i n q u i n a m e n t o [NSONDE ] [ NRILIEVI ] ; La direttiva #define può essere usata per dichiarare costanti L uso delle quadre può essere esteso ad oltre 2 dimensioni. Ad esempio: double molte dimensioni[100][20][23][50]; Nel caso di due dimensione possiamo parlare di matrice Nell esempio NSONDE è convenzionalmente considerato il numero di righe e NRILIEVI il numero di colonne

Scorrere una matrice: esempio di stampa #d e f i n e RIGHE 50 #d e f i n e COLONNE 60 f l o a t m a t r i c e [ RIGHE ] [ COLONNE ] ; i n t main ( ) { i n t r, c ;... f o r ( r =0; r<righe ; r=r +1) { f o r ( c =0; c<colonne; c=c+1) { p r i n t f ( % f, m a t r i c e [ r ] [ c ] ) ; } p r i n t f ( / n ) ; } r e t u r n 0 ; }

Passaggio di un array multi-dimensionale ad una funzione Quando si dichiara una funzione che prende come parametro un array multi-dimensionale, solo la prima dimensione può essere lasciata non specificata Esempio: void stampa matrice(int mat[][colonne]); La dimensione specificata nel parametro formale deve coincidere con quella specificata nella dichiarazione del parametro attuale Approfondimenti... : come rappresentare un array bi-dimensionale con un array uni-dimensionale?

Esercizi 1. Scrivere una funzione che data una matrice di interi e un vettore di interi metta nella cella i del vettore la somma degli elementi pari della riga i della matrice: void somma righe(int matrice[][colonne], int dim, int vett[]); 2. Scrivere una funzione che scambi le righe e le colonne di una matrice 3. Scrivere una funzione che decida se due matrici di interi se sono uguali

Le stringhe in C Definizione (Stringa in C) In C una stringa è una sequenza contigua di caratteri che termina con il carattere \0. Le stringhe sono implementate come array di caratteri char Come per gli array la dimensione è decisa in fase di compilazione Il carattere di terminazione denota la porzione (inizale) dell array che contiene i caratteri significativi della stringa

Dichiarazione di una stringa Stringa con al massimo 99 caratteri (posizioni 0-98): char s t r i n g a [ 1 0 0 ] ; Inizializzazione di una stringa char m i o s a l u t o [ 1 0 0 ] = H e l l o world! ; Attenzione: l operatore = può essere usato in fase di inizializzazione ma non di assegnamento

Passaggio di una stringa ad una funzione Il passaggio di una stringa ad una funzione segue le regole dell array Attenzione: non è necessario passare la dimensione perchè c è il carattere di fine stringa Esempio: void stampa stringa(char str[]);

Esempio: Stampa di una stringa carattere per carattere void s t a m p a s t r i n g a ( char s [ ] ) { i n t i =0; while ( s [ i ]!= \0 ) { p r i n t f ( % c, s [ i ] ) ; i = i +1; } } Nota: normalmente si usa printf( %s, stringa);;

Calcolare la lunghezza di una stringa i n t s t r l e n ( char s [ ] ) { i n t l e n =0; while ( s [ l e n ]!= \0 ) { l e n = l e n + 1 ; } return l e n ; }

Alcune note L operatore == non può essere usato per stabilire se due stringhe contengono gli stessi carattero L operatore = non può essere usato per copiare il contenuto di una stringa in un altra Per facilitare queste operazioni si usa la librerira standard string.h

Esercizi 1. Scrivere una funzione che decida se due stringhe sono identiche 2. Scrivere una funzione che decida se una stringa contiene almeno una vocale minuscola 3. Scrivere una funzione che decida se una stringa ha più di tre consonanti consecutive