Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-12-2005, 11:19   #1
Louder Than Hell
Senior Member
 
L'Avatar di Louder Than Hell
 
Iscritto dal: Nov 2002
Città: Cagliari
Messaggi: 844
[C] problemi di pila...

Ciao ragazzi, è da un sacco che non posto qui ma da quando mi sono iscritto in informatica penso che torneremo a sentirci qualche volta

Il mio problema è questo: in facoltà stiamo facendo liste fifo e lifo, io sono 3 giorni che mi scranio su questa storia e finalmente sono riuscito a far girare un programma stupidissimo che però mi da qualche problema.

Codice:
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>

//struttura di elemento
struct elemento{
int inf;
struct elemento *pun;
}


//main
main(){

   struct elemento *puntatesta = NULL;
   struct elemento *puntaultimo = NULL;
   struct elemento *puntapenultimo = NULL;
   struct elemento *tmp = NULL;
   int scelta = -1;
   int ele;

   //menu   
   
while(scelta!=0){
printf("\n\n---------------------\nGestione di una pila\n\n0)esci\n1)inserisci elemento\n2)elimina ultimo elemento inserito\n3)visualizza la pila\n---------------------\nscelta: ");
scanf("%d", &scelta);

switch(scelta){
   //aggiungo un elemento
case 1:
   //se è il primo gli associo puntatesta
if(puntatesta==NULL){
   puntaultimo=(struct elemento *)malloc(sizeof(struct elemento));
   printf("\n\ninserisci il primo valore: ");
   scanf("%d",&puntaultimo->inf);
   printf("verifica: %d",puntaultimo->inf);
   puntatesta=puntaultimo;
   puntaultimo->pun=NULL;
   puntapenultimo=puntatesta;
}
//se no gli assocuo puntaultimo
else{
   puntapenultimo=puntaultimo;
   puntaultimo=puntaultimo->pun;
   puntaultimo=(struct elemento *)malloc(sizeof(struct elemento));   
   printf("\n\ninserisci il valore: ");
   scanf("%d",&puntaultimo->inf);
   printf("verifica: %d",puntaultimo->inf);
   puntaultimo->pun=NULL;
}

break;
//elimino l'ultimo elemento inserito e faccio puntare a punta ultimo il penultimo elemento memorizzato grazie a puntapenultimo
case 2:
   if(puntaultimo!=NULL && puntaultimo!=puntatesta){
   printf("\n\nEliminazione dell'ultimo elemento inserito\nUltimo elemento: %d", puntaultimo->inf);
   free(puntaultimo);
   puntaultimo=puntapenultimo;
   }
   else
      printf("\n\nEliminazione del primo elemento inserito\nelemento: %d", puntatesta->inf);
   free(puntatesta);
   puntatesta=NULL;
break;
//visualizzo la pila
case 3:
   printf("\n\nvisualizzazione della pila:");
   //se esiste il primo elemento procedo
   if(puntatesta==NULL)
      printf("\n\nNon ci sono elementi nella pila!");
   else{
      //stampo tutti i dati contenuti in tmp facendolo passare dal primo elemento della pila (puntatesta) fino all'ultimo(finche non diventa NULL)
   tmp=puntatesta;
   while(tmp!=NULL){
      printf("\n%d",tmp->inf);
      tmp=tmp->pun;
   }
   }

break;

default:
printf("\n\ninserisci un numero corretto");
}
}
Sper sia leggibile..non sono abituato a far leggere il mio codice

I problemi sono:
1) I dati li memorizza però se faccio "stampare" la lista mi fa vedere solo il primo. Eppure sono sicuro che li memorizzi tutti perchè se vado ad eliminare un dato funziona tutto -quasi- alla perfezione
2)In che modo posso far eliminare l'ultimo dato e far puntate puntaultimo al penultimo per poi libere la memoria? Nel codice ho usato *puntapenultimo da sostituire a *puntaultimo se si cancella un elemento ma proprio mentre scrivevo qui mi sono accorto di aver fatto un immane cacchiata:
Quote:
Eliminazione dell'ultimo elemento inserito
*** glibc detected *** double free or corruption (fasttop): 0x0804a008 ***
Ultimo elemento: 134520848Aborted (core dumped)
Ho visto che siete molto gentili con i niubbi per cui vi ringrazio sin d'ora per l'immenso aiuto che mi darete

PS: cionci conto su di te, il mio nick ti dovrebbe dire qualcosa

PPS: Perchè vuole una riga bianca alla fine?
Quote:
pila3.c:86:2: warning: no newline at end of file
__________________
Non ho paura dei computer, ma della loro eventuale mancanza. (Asimov)
Una delle principali cause della caduta dell'Impero Romano fu che, privi dello zero, non avevano un modo per indicare la corretta terminazione dei loro programmi C. (Firth)

Ultima modifica di Louder Than Hell : 09-12-2005 alle 11:25.
Louder Than Hell è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2005, 12:37   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Ciao, in <questo> thread ho postato un sorgente per la gestione di una coda (fifo). Vedi se magari ti può essere utile.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2005, 12:49   #3
Louder Than Hell
Senior Member
 
L'Avatar di Louder Than Hell
 
Iscritto dal: Nov 2002
Città: Cagliari
Messaggi: 844
Quote:
Originariamente inviato da andbin
Ciao, in <questo> thread ho postato un sorgente per la gestione di una coda (fifo). Vedi se magari ti può essere utile.
Grazie andrea, avevo già cercato ma quel thread non l'avevo visto
Utilizzi alcune cose che io non ho ancora fatto tipo memset, gli ho dato un occhiata ed è strutturato in modo un pò diverso dal mio. Ora gli occhi mi stanno esplodento mi prendo una pausa e lo analizzo più avanti con calma.

La curiosità di sapere come mai
Codice:
   while(tmp!=NULL){
      printf("\n%d",tmp->inf);
      tmp=tmp->pun;
   }
Non funziona rimane comunque, questo è il problema che mi preme di più


__________________
Non ho paura dei computer, ma della loro eventuale mancanza. (Asimov)
Una delle principali cause della caduta dell'Impero Romano fu che, privi dello zero, non avevano un modo per indicare la corretta terminazione dei loro programmi C. (Firth)
Louder Than Hell è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2005, 17:46   #4
Louder Than Hell
Senior Member
 
L'Avatar di Louder Than Hell
 
Iscritto dal: Nov 2002
Città: Cagliari
Messaggi: 844
Ottimo ho modificato un pò di cosette ed ora sembra funzionare tutto:

Codice:
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>

//struttura di elemento
struct elemento{
int inf;
struct elemento *next;
struct elemento *prev;
}


//main
main(){

   struct elemento *puntatesta = NULL;
   struct elemento *puntaultimo = NULL;
   struct elemento *tmp = NULL;
   int scelta;
   int ele;

   //menu   
   
do{
printf("\n\n---------------------\nGestione di una pila\n\n0)esci\n1)inserisci elemento\n2)elimina ultimo elemento inserito\n3)visualizza la pila\n---------------------\nscelta: ");
scanf("%d", &scelta);

switch(scelta){
   //aggiungo un elemento
case 1:
   //se è il primo gli associo puntatesta
if(puntatesta==NULL){
   puntaultimo=(struct elemento *)malloc(sizeof(struct elemento));
   printf("\n\ninserisci il primo valore: ");
   scanf("%d",&puntaultimo->inf);
   printf("verifica: %d",puntaultimo->inf);
   puntatesta=puntaultimo;
   puntatesta->next=NULL;
}
//se no gli associo puntaultimo
else{

   puntaultimo->next=(struct elemento *)malloc(sizeof(struct elemento));   
   tmp=puntaultimo;
   puntaultimo=puntaultimo->next;
   puntaultimo->prev=tmp;   
   printf("\n\ninserisci il valore: ");
   scanf("%d",&puntaultimo->inf);
   printf("verifica: %d",puntaultimo->inf);
   puntaultimo->next=NULL;
}

break;
//elimino l'ultimo elemento inserito
case 2:
   if(puntatesta==NULL){
      printf("\n\nnon ci sono elementi da eliminare!");
   break;
   }
   else if(puntatesta==puntaultimo){
      printf("\n\nEliminazione del primo elemento inserito\nelemento: %d", puntatesta->inf);
      free(puntatesta);
      puntatesta=NULL;
      break;
   }
   else if(puntaultimo!=puntatesta){
   printf("\n\nEliminazione dell'ultimo elemento inserito\nUltimo elemento: %d", puntaultimo->inf);
   tmp=puntaultimo->prev;
   free(puntaultimo);
   puntaultimo=tmp;
   puntaultimo->next=NULL;
   break;
   }

//visualizzo la pila
case 3:
   printf("\n\nvisualizzazione della pila:");
   //se esiste il primo elemento procedo
   if(puntatesta==NULL)
      printf("\n\nNon ci sono elementi nella pila!");
   else{
      //stampo tutti i dati contenuti in tmp facendolo passare dal primo elemento della pila (puntatesta) fino all'ultimo(finche non diventa NULL)
      tmp=puntatesta;
   while(tmp!=NULL){
      printf("\n%d",tmp->inf);
      tmp=tmp->next;
   }
   }

break;

default:
printf("\n\ninserisci un numero corretto");
}
}while(scelta!=0);
}
Grazie
__________________
Non ho paura dei computer, ma della loro eventuale mancanza. (Asimov)
Una delle principali cause della caduta dell'Impero Romano fu che, privi dello zero, non avevano un modo per indicare la corretta terminazione dei loro programmi C. (Firth)
Louder Than Hell è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Scuderia Ferrari HP svela la SF-26: bell...
Beats Studio Pro in forte sconto su Amaz...
Il 'Windows open-source' compie 30 anni:...
Forza Horizon 6: ulteriori dettagli emer...
Nuovi limiti ai biocarburanti: quelli a ...
HONOR Magic8 Pro: lo smartphone che vede...
Batterie allo stato solido anche da Geel...
Fable torna ad essere protagonista: annu...
Google integra i dati di Gmail e Foto de...
Curl ha chiuso il suo bug bounty: tutta ...
Ericsson 5G Advanced: geolocalizzazione ...
Elon Musk annuncia che Tesla, entro il 2...
Speciale robot aspirapolvere in offerta ...
Epic Games e Google: emerge una partners...
Apple ridisegna i vertici: John Ternus a...
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: 12:36.


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