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 elementi () tutti di tipo individuati singolarmente da un numero intero int fra 0 e (detto indice).

2️⃣ Dichiarazione
dove:
- → identificatore (nome);
- → tipo;
- → costante intera, dimensione;
#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
- Numero elementi predefinito → array statici = dimensione array costante (nota a compile-time)
- Numero elementi specificato a run-time → array semidinamici = dimensione array qualsiasi (intera)
- Numero elementi non specificato → array dinamici
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
- NO confronto e assegnamento
int A[10]; int B[10]; A == B; // ----> ERRORE A = B; // ----> ERRORE
- NO I/O su array
int A[10]; printf("%d", A); // ----> ERRORE scanf("%d", &A); // ----> ERRORE
Soluzione a questi problemi
per eseguire correttamente operazioni di confronto, assegnamento ed I/O è spesso necessario utilizzare dei cicli.
- Confronto e assegnamento:
esempio:
A[i] == B[j]
esempio:
A[i] = 5
- I/O su array:
esempio:
scanf("%d", &A[3])
esempio:
printf("%d", A[i])
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


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
Soluzione
#include <stdio.h> int main() { int a[10]; printf("inserisci 10 valori: "); for (int i=0; i<10; i++) { scanf("%d", &a[i]); } bool palindromo = true; for(int i=0; i<5; i++) { if(a[i] != a[9-i]) { palindromo = false; } } if(palindromo) { printf("l'array e' palindromo"); } else { printf("l'array NON 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
Soluzione
#include <stdio.h> int main(){ int a[10]; //memorizzo l'array printf("inserisci 10 numeri interi: "); for(int i=0; i<10; i++) { scanf("&d", &a[i]); } //per ogni numero dell'array for(int i=0;i<10;i++) { // voglio contare quante volte appare a[i] int volte=0; //controllo quante volte compare a[i] for(int j=0; j<10; j++) { if(a[j] == a[i]) { volte++; } } if(volte == 1) { printf("%d ", a[i]); } } return 0; }