Home Insegnanti Contattami Portfolio

Array Monodimensionali

1️⃣ Descrizione

Un array monodimensionale (o vettore) è una sequenza di variabili dello stesso tipo che vengono situate consecutivamente nella memoria ed alle quali è possibile accedere usando uno stesso nome (identificatore) a cui viene aggiunto un indice. Pensiamo all'array come ad un insieme di cassetti numerati.

Definizione: Sequenza di nn elementi (n0n ≥ 0) tutti di tipo tt individuati singolarmente da un numero intero int fra 0 e n1n-1 (detto indice).

2️⃣ Dichiarazione

t  A[n];t \ \ A[n];

dove:

#define N 10
const int M = 100

//dichiara ad esempio un array di 10 elementi
int A[N]; 

//dichiara un array di 10 elementi float
float V[10]; 

//dichiara un array di 100 elementi
int B[M]; 

//array di interi con la dimensione definita implicitamente
int C = {3,5,6,2,1}

//array di interi parzialmente inizializzato
int D[10] = {3,5,6,2,1}

//array di interi totalmente inizializzato
int E[10] = {3,5,6,2,1,8,4,7,9,0}

//si può anche indicare {} inizializza gli elementi dell'array a zero
int F[N] = {0};

3️⃣ Dimensione Array

  1. Numero elementi predefinito → array statici = dimensione array costante (nota a compile-time)
  1. Numero elementi specificato a run-time → array semidinamici = dimensione array qualsiasi (intera)
  1. Numero elementi non specificato → array dinamici
📖
Nota Bene: per gli array statici e semidinamici, una volta allocata, la dimensione dell’array non è più modificabile.

4️⃣ Operazioni

Accesso elemento

int vett[5] = {2, 0, 1, 6, 3};
vett[4];  // -> mi riferisco al valore 3

Lettura elemento

int vett[5];
scanf("%d", &vett[2]); // inserisco un valore nella posizione 3

Scrittura elemento

int vett[5] = {2, 0, 1, 6, 3};
printf("%d", vett[2]); //Output: 1

Cosa NON si può fare

Soluzione a questi problemi

per eseguire correttamente operazioni di confronto, assegnamento ed I/O è spesso necessario utilizzare dei cicli.

5️⃣ Algoritmi principali

Stampa Array

int vett[5] = {2, 0, 1, 6, 3};

for (int i=0; i<5; i++) {
		printf("%d ", vett[i]);
}

// Output: 2 0 1 6 3

Leggi Array

int vett[5];

for (int i=0; i<5; i++) {
		scanf("%d", &vett[i]);
}

Ordinamento Array (Bubble Sort)

int dim = 5;
int vett[] = {2, 0, 1, 6, 3};

for (int i = 0; i < dim; i++) {
        for (int j = 0; j < dim-1; j++) {
            if (vett[j] > vett[j+1]) {
                int temp = vett[j];
                vett[j] = vett[j+1];
                vett[j+1] = temp;
            }
        }
 }

Ragionamento per “swappare” gli elementi di un array tra di loro:

Ricerca Massimo/Minimo

vett[5] = {2, 5, 1, 0, 3};

int max = vett[0];
    
for (int i=0; i<5; i++) {
    if (max < vett[i]) {
        max = vett[i];
    }
}

printf("%d", max);

// Output: 5

📑 Esercizi

35 Esercizi con gli array
31 Esercizi svolti di programmazione con gli array in C++, risolvibili anche con altri linguaggi: Pascal, Java, Python, C.
https://ticoprof.wordpress.com/2016/04/26/esercizi-con-gli-array/

ESERCIZIO 1

Leggere un array di interi di 10 posizioni e verificare se è palindromo (ovvero se non cambia ad essere letto dalla prima cella all’ultima o viceversa).

Esempio Output:
inserisci 10 valori: 3 5 7 9 1 1 9 7 5 3
l'array e' palindromo

ESERCIZIO 2

Leggere un array di 10 interi e stampare solo i numeri che appaiono nell'array una volta soltanto.

Esempio Output:
inserisci 10 numeri interi: 1 3 5 3 2 0 5 2 3 4
1 0 4

QUIZ