Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16-ak0001nl combina RTX 5080 Laptop e Ryzen AI 9 HX 375 in un desktop replacement potente e ben raffreddato, con display 240 Hz e dotazione completa. Autonomia limitata e calibrazione non perfetta frenano l'entusiasmo, ma a 2.609 euro è tra le proposte più interessanti della categoria.
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-07-2012, 20:37   #1
junkieman
Junior Member
 
Iscritto dal: May 2011
Messaggi: 3
[C] Problemi su gestione liste e allocazione...urgente!

Primo thread, ragazzi, spero possiate darmi una mano...

Ho da poco iniziato a programmare facendomi le ossa sul C, e mi sono
bloccato nel cercare di realizzare il programma che segue, la cui traccia è
all'incirca questa:

---> Verificata l'esistenza di un file binario contenente le informazioni
relative a un singolo esame su una classe di studenti (nome, cognome,
matricola, voto): si scriva un codice contenente una funzione che
carichi in memoria heap i dati dell'intera classe, e si crei poi la lista ordinata
in ordine crescente di voto per i soli studenti che hanno superato (18/30)
l'esame.

Ho già realizzato il codice per creare il suddetto file binario e fila liscio,
ho poi cercato di svolgere la traccia e, in compilazione, non ci sono
errori o warning...ma il programma va in crash in esecuzione.

Dove sbaglio?

Il codice della funzione principale, a cui viene passato
il file già aperto, è:


Codice:
void carica(FILE *fb)
{
     struct stud *info;
     struct nodo *nuovo, *corr, *prec;
     struct nodo *inizio = NULL;
     
     unsigned int tot;
     int n, i;
     
     fseek(fb, 0, SEEK_END);
     tot = ftell(fb);
     n = (int) tot / sizeof(struct stud);
     rewind(fb);
     
     info = malloc(sizeof(struct stud)*n);
     for(i=0; i<n; i++)
     {
          fread(info, sizeof(struct stud), 1, fb);
          if((info->voto) >= 18)
          {
              nuovo = (struct nodo*)malloc(sizeof(struct nodo));

              if(nuovo != NULL)
              {
                 strcpy(nuovo->nome, info->nome);
                 strcpy(nuovo->cognome, info->cognome);
                 strcpy(nuovo->matricola, info->matricola);
                 nuovo->voto = info->voto;
                 nuovo->pros = NULL;
              
                 prec=NULL;
                 corr=inizio;
              
                 while( ( corr != NULL) && ( nuovo->voto >= corr->voto ) )
                 {
                     prec = corr;
                     corr = corr->pros;
                 }
              
                 if(prec == NULL)
                 {
                     nuovo->pros = inizio;
                     inizio = nuovo;
                 }
                 else
                 {
                      prec->pros = nuovo;
                      nuovo->pros = corr;
                 }
              }
              else
              {
                  printf("\n\nMemoria esaurita!\n");
                  break;
              }
              free(nuovo);       
          }
          free(info); 
     }    
}


Grazie in anticipo a chiunque volesse rispondermi...buon weekend!
junkieman è offline   Rispondi citando il messaggio o parte di esso
Old 21-07-2012, 21:38   #2
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12960
Crasha nel caricamento o altrove?

Perché ad una occhiata molto rapida, fai delle free su "nuovo" che non vedo perché tu debba fare (se vuoi accedere al di fuori della funzione alla struttura).
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 22-07-2012, 11:35   #3
junkieman
Junior Member
 
Iscritto dal: May 2011
Messaggi: 3
Tutto risolto, grazie...mi sono spremuto le meningi e, come era ovvio, la soluzione era a portata di mano..

..in effetti la traccia non specificava di caricare in un'unica area di memoria tutti i dati in una sola volta quindi, una volta verificato (attraverso la
sequenza fseek-->rewind) con quante struct avevo a che fare nel
file di partenza ho usato un ciclo per allocarle una per volta (in una
struct stud *temp, su cui applicare free alla fine di ogni iterazione) e, nel
caso il requisito di base fosse stato verificato (voto>=18), portare i
dati di quella struct in un nodo e inserirlo nella lista:

Codice:
for(i=0; i<n; i++)
     {
          temp = (struct stud*)malloc(sizeof(struct stud));
          fread(temp, sizeof(struct stud), 1, fb);
          if((temp->voto) >= 18)
          {
              nuovo = (struct nodo*)malloc(sizeof(struct nodo));

              if(nuovo != NULL)
              {
...eccetera.

Ho infine aggiunto una funzione (interna a carica) per stampare a video
i risultati finali e..
Codice:
void stampaLista(struct nodo *testa)
{
     if(testa != NULL)
     {
         printf("\n\nLa lista risultante e\':\n");
              
         while(testa != NULL)
         {
             printf("%s  ", testa->nome);
             printf("%s  ", testa->cognome);
             printf("%s  ", testa->matricola);
             printf("%d\n", testa->voto);
             testa = testa->pros;        
         }     
     }
     else
         printf("\n\nLa lista e\' vuota!\n\n");
}
..voilà, il gioco è fatto.

Spero queste "piccole" dritte possano essere utili a qualcuno con
problemi simili!

Have a great day!
junkieman è offline   Rispondi citando il messaggio o parte di esso
Old 22-07-2012, 17:27   #4
smemo90
Junior Member
 
Iscritto dal: Jul 2012
Messaggi: 1
scusa potresti passarmi l'intero codice del tuo programma per favore? mi servirebbe capire come hai proceduto (sono alle prime armi e ho avuto un compito simile). Grazie!
smemo90 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Un Haier QLED 4K UHD 50'' con 6 Mesi DAZ...
Spotify dà i numeri: nel 2025 l'i...
Meta accelera sui chip AI proprietari: q...
IT-Wallet diventerà sempre pi&ugr...
La torta a 5 strati più costosa d...
Il nuovo MacBook Neo ha una memoria SSD ...
Xbox Project Helix, le prime specifiche ...
Annunci pubblicitari sulla TV quando cam...
Prezzi aumentati del 50% durante la nott...
Sconti studiati per singolo utente: Sony...
Addio alla Kia Niro EV, il crossover sar...
Apple crede nel suo iPhone Fold: la prod...
Fortnite, un nuovo listino per i pacchet...
Ecco i nuovi Sonos Play ed Era 100 SL: d...
Razer svela il futuro del gaming potenzi...
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: 08:58.


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