Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Abbiamo giocato a lungo a Battlefield 6, abbiamo provato tutte le modalità multiplayer, Redsec, e le numerose personalizzazioni. In sintesi, ci siamo concentrati su ogni aspetto del titolo per comprendere al meglio uno degli FPS più ambiziosi della storia dei videogiochi e, dopo quasi due mesi, abbiamo tirato le somme. In questo articolo, condividiamo con voi tutto ciò che è Battlefield 6, un gioco che, a nostro avviso, rappresenta esattamente ciò che questo genere attendeva da tempo
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Abbiamo messo alla prova il drone Antigravity A1 capace di riprese in 8K a 360° che permette un reframe in post-produzione ad eliche ferme. Il concetto è molto valido, permette al pilota di concentrarsi sul volo e le manovre in tutta sicurezza e decidere con tutta tranquillità come gestire le riprese. La qualità dei video, tuttavia, ha bisogno di uno step in più per essere competitiva
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-03-2007, 22:24   #1
Capua
Junior Member
 
Iscritto dal: Dec 2006
Messaggi: 15
[C] Chiarimento liste concatenate

Qualcuno può commentarmi questo esercizio riga per riga in cui creo una lista concatenata in cui gli elementi sono dati in input fino all'inserimento di 9999? Vorrei cercare di capire meglio l'esercizio visto che non è completamente opera mia...Vi ringrazio anticipatamente..

/* STRUTTURA GLOBALE */

typedef struct lista {
int val;
struct lista *next;
} LISTA;


/* FUNZIONE MAIN */

int main (void){

LISTA *testa,*nuovo,*coda;

testa=NULL;
int elemento;

while (elemento!=9999){
printf("inserisci elemento, (9999 per terminare) " );
scanf("%d",&elemento);

if (elemento!=9999){

/* CREAZIONE LISTA */

nuovo=(LISTA*)malloc (sizeof(LISTA));
nuovo->val=elemento;
if(testa==NULL){

testa=nuovo;
nuovo->next=NULL;
coda=nuovo;
}

else {
nuovo->next=NULL;
coda->next=nuovo;
coda=nuovo;

}
}
}

printf("gli elementi dati in input sono: ");
stampa_lista(testa);
printf("\n");

return 0;
}
Capua è offline   Rispondi citando il messaggio o parte di esso
Old 23-03-2007, 02:08   #2
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Codice:
typedef struct lista {
int val;
struct lista *next;
} LISTA;
Qui dichiari il tipo LISTA, il quale e' adatto a contenere un valore intero e ad avere un puntatore ad un eventuale elemento successivo, il quale e' dello stesso tipo.
Come avrai ben capito, questa struttura si utilizza quando non sai a priori il numero di elementi che puoi avere. Ovviamente ha vantaggi e svantaggi, non e' questa la sede.
In generale, per utilizzare una struttura del genere, avrai bisogno di memorizzare il puntatore al primo elemento della lista. Da questo, poi, potrai facilmente scorrere tutta la lista seguendo i puntatori next.

Codice:
LISTA *testa,*nuovo,*coda;
Eccoli qui! I nomi non sono stati scelti a caso. Anzi, sono ben scelti. Stando ai nomi, ti aspetterai che testa memorizzi sempre l'indirizzo del primo elemento della lista (i.e. quello da cui potrai sempre scandire tutta la lista seguendo i next).
Potrai gia' immaginare che nuovo sara' l'elemento nuovo che vuoi inserire nella lista, e coda sara' il puntatore all'ultimo elemento.
Perche' ti serve il puntatore all'ultimo elemento, visto che con il puntatore "testa" posso scandire tutta la lista? Evidentemente perche' il programma vorra' inserire i nuovi elementi in coda, e scandire tutte le volte la lista potrebbe essere piuttosto oneroso (devi sempre far passare tutti gli elementi....). Meglio ricordarsi qual e' l'ultimo elemento, no?

Codice:
testa=NULL;
All'inizio la lista e' vuota, ed il puntatore alla testa e' ovviamente NULL.

Codice:
while (elemento!=9999){
printf("inserisci elemento, (9999 per terminare) " ); 
scanf("%d",&elemento);
Qui possiamo vedere il primo errore. Il programmatore aveva intenzione di fare un ciclo che fosse eseguito fintanto che elemento non assume il valore 9999. Prima di entrare in questo ciclo e' percio' necessario dare un valore ad elemento che sia diverso da 9999. Il programmatore se l'e' dimenticato. Siccome se non dai alcun valore il contenuto e' indeterminato (potrebbe esserci dentro qualsiasi cosa) c'e' buona probabilita' che non sia 9999, pertanto il programma SEMBRA funzionare correttamente.
Non funzionera' correttamente quando dovrai farlo vedere al cliente finale

Codice:
if (elemento!=9999){
Certo, se elemento == 9999 non fai niente. Alla prossima iterazione, uscirai

Codice:
nuovo=(LISTA*)malloc (sizeof(LISTA)); 
nuovo->val=elemento;
Qui possiamo vedere il secondo, subdolo, errore.
La malloc() ti alloca memoria dinamica. Signfica che, quando questa operazione si conclude con successo, la variabile nuovo assumera' un nuovo valore: puntera' ad un'area di memoria valida e sufficientemente grande per contenere il numero di bytes che hai specificato nel parametro.
Per esempio,
Codice:
char *p;
p = (char *)malloc(3);
hai la certezza che, se l'operazione si conclude con successo, p conterra' l'indirizzo di un'area di memoria che puo' contenere almeno 3 byte.
La scrittura (LISTA *) oppure (char *) si chiama type cast ed e' una semplice conversione di tipo. Siccome la malloc() non puo' sapere come utilizzerai quella memoria, ti riporta un puntatore "neutro" (la maggior parte dei nuovi sistemi riporta un puntatore a void, quelli vecchi a char).
Con questo type cast semplicemente dici: "utilizzo questa memoria per puntare ad un tipo LISTA", che poi e' il tipo della variabile a cui assegni.

Si parlava di errore: infatti ho sempre detto "se l'operazione si conclude con successo". Nel caso non si concluda con successo, la malloc() ti riporta NULL, pertanto l'istruzione
Codice:
nuovo->val=elemento;
mandera' in crash l'applicazione. Questo e' un "red-eyes crash", nel senso che spesso, nei programmi piuttosto grandi, ti obbliga a far la nottata a cercarlo.
Metti sempre il controllo: se non si riesce ad allocare memoria, piuttosto che niente, stampa un messaggio di errore ed esci.

Codice:
if(testa==NULL){

testa=nuovo; 
nuovo->next=NULL;
coda=nuovo;
}
OK! E' la prima volta che esegui il ciclo. La lista e' ancora vuota, pertanto l'elemento che hai inserito e' la testa della lista. testa (puntatore al primo elemento) pertanto ha lo stesso indirizzo del nuovo elemento (i.e. testa=nuovo).
D'altronde anche coda ha lo stesso indirizzo del nuovo elemento, in quanto la lista e' composta da un solo elemento (i.e. coda=nuovo).
L'elemento successivo? Non esiste, hai inserito un solo elemento, pertanto nuovo->next e' messo a NULL

Codice:
else {
nuovo->next=NULL;
coda->next=nuovo;
coda=nuovo; 

}
Abbiamo detto che si vuole inserire in coda. Questa e' la conferma. Siccome abbiamo visto che l'if stabilisce se stai inserendo il primo elemento, l'else significa che la tua lista ha almeno gia' un elemento. Esiste almeno la testa.
Quindi, siccome vogliamo inserire in coda, possiamo mettere:
- nuovo->next a NULL (e' l'ultimo, dietro di lui il vuoto);
- coda->next (cioe' quello che prima era l'ultimo elemento) ora punta a questo qui, appena inserito.
- coda = nuovo (questo e' il nuovo ultimo dei fratelli).

Scusa se sono stato prolisso
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 23-03-2007, 20:40   #3
Capua
Junior Member
 
Iscritto dal: Dec 2006
Messaggi: 15
Grazie mille, me l'hai commentato alla perfezione!
Capua è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
La costruzione del telescopio spaziale N...
HBO ha cancellato la produzione della se...
OpenAI ha pensato a una partnership (o a...
Starlink Mobile: SpaceX potrebbe lanciar...
Volkswagen trasforma lo stabilimento di ...
Meta AI più reattivo e imparziale...
In Cina la prima GPU discreta al mondo c...
Vertiv CoolCenter, il sistema di raffred...
Konecta entra nel Kraken BPO Partner Pro...
Un dialogo con l'AI sposta voti meglio d...
iPhone 17 al minimo storico: oggi il 256...
Gli utenti italiani scelgono ChatGPT: &e...
Anche Xiaomi avrà il suo trifold:...
È Natale in casa Tesla: arriva la...
Shai-Hulud diventa più cattivo: e...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 23:27.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v