Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-03-2008, 13:57   #1
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
[C] Inversione di una pila

Come mai mi da errore questo semplice programma per invertire una pila?

vi incollo anche una funzione che uso, la top
Codice HTML:
int Top(pilaPtr P){
        
        if(P!=NULL){
                    return P->data;}else{
                           return NULL;}}
Codice HTML:
pilaPtr Inverti(pilaPtr P){
        
        pilaPtr P2=NULL;
        pilaPtr P3=NULL;
        int e=0;
        
        while((Empty(P))==0){
                             e=Top(P);
                             P2=Push(P2,e);
                             P3=Push(P3,e);
                             P=Pop(P);}
                             
        return P2;}
Ignorate P3 che mi serivrà dopo per ricostruire la pila originale
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2008, 14:39   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Non conosco l'implementazione di pila che hai, ma sei sicuro che la seguente sia corretta?

Quote:
Originariamente inviato da xbubbax Guarda i messaggi
P=Pop(P);
Solitamente la Pop di una pila ritorna un elemento, non la pila.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2008, 14:57   #3
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ecco tutte le mie funzioni
Codice HTML:
#include <stdio.h>
#include <stdlib.h>

struct nodo{
       int data;
       struct nodo *next;};
       
typedef struct nodo nodo;
typedef struct nodo *pilaPtr;

int Empty(pilaPtr P){
    
    if(P==NULL){
                return 1;}else{
                       
                       return 0;}}
                       
pilaPtr Push(pilaPtr P, int e){
        
        pilaPtr temp=NULL;
        
        temp=(pilaPtr)malloc(sizeof(nodo));
        
        if(temp){
                 temp->data=e;
                 temp->next=P;
                 P=temp;
                 return P;}else{
                        
                        printf("Memoria Esaurita\n");}}
                        
int Top(pilaPtr P){
        
        if(P!=NULL){
                    return P->data;}else{
                           return NULL;}}
                    
pilaPtr Pop(pilaPtr P){
        
        pilaPtr temp=NULL;
        
        if(!Empty(P)){
                      temp=P;
                      P=temp->next;
                      free(temp);}else{
                                       
                                       printf("La Pila E' Gia' Vuota\n");}}
                                       
void Stampa(pilaPtr P){
     
     while(P!=NULL){
                    printf("%d\n", P->data);
                    P=P->next;}}
                        
                        
        
        
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2008, 15:18   #4
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
E' una brutta indentazione.
Comunque la POP non restitusice nulla, non dovrebbe neppure compilare.
Penso che debba restituire
temp
ma io la pila la farei diversamente. Farei restituire l'intero alla POP, oppure NULL se la pila e' vuota.
In questo modo potrei usare anche solo la funzione POP per eseguire l'esercizio. POPpo dalla vecchia e PUSHo nella nuova fino a quando ci sono valori, ovvero esco quando ottengo NULL.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2008, 18:34   #5
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
Allora, ho corretto la mia Pop, avevo dimenticato di inserire Return P. Ho provato il programma e funziona, ovvero crea una pila con gli elementi in ordine inverso, però quando inserisco un secondo while per rimettere la pila con i suoi elementi nel suo ordine originario mi da errore, non capisco perchè
Codice HTML:
#include <stdio.h>
#include <stdlib.h>
#include "funzioni_pile.h"

pilaPtr Inverti(pilaPtr P){
        
        pilaPtr P2=NULL;
        pilaPtr P3=NULL;
        int e=0;
        
        while((Empty(P))==0){
                             e=Top(P);
                             P2=Push(P2,e);
                             P3=Push(P3,e);
                             P=Pop(P);}
                             
        while((Empty(P2))==0){
                              e=Top(P2);
                              P1=Push(P1,e);
                              P2=Pop(P2);}
        
                              
        return P3;}
                             
        
        
int main(void){
    
    pilaPtr P1=NULL;
    pilaPtr P2=NULL;
    
    P1=Push(P1,1);
    P1=Push(P1,2);
    P1=Push(P1,3);
    
    printf("\n");
    
    Stampa(P1);
    
    printf("\n");
    
    P2=Inverti(P1);
    
    Stampa(P2);
    
    system("PAUSE");}
    
                             
                             
                             
Codice HTML:
#include <stdio.h>
#include <stdlib.h>

struct nodo{
       int data;
       struct nodo *next;};
       
typedef struct nodo nodo;
typedef struct nodo *pilaPtr;

int Empty(pilaPtr P){
    
    if(P==NULL){
                return 1;}else{
                       
                       return 0;}}
                       
pilaPtr Push(pilaPtr P, int e){
        
        pilaPtr temp=NULL;
        
        temp=(pilaPtr)malloc(sizeof(nodo));
        
        if(temp){
                 temp->data=e;
                 temp->next=P;
                 P=temp;
                 return P;}else{
                        
                        printf("Memoria Esaurita\n");}}
                        
int Top(pilaPtr P){
        
        if(P!=NULL){
                    return P->data;}else{
                           return NULL;}}
                    
pilaPtr Pop(pilaPtr P){
        
        pilaPtr temp=NULL;
        
        if(!Empty(P)){
                      temp=P;
                      P=temp->next;
                      free(temp);
                      return P;}else{
                                       
                                       printf("La Pila E' Gia' Vuota\n");}}
                                       
void Stampa(pilaPtr P){
     
     while(P!=NULL){
                    printf("%d\n", P->data);
                    P=P->next;}}
                        
                        
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2008, 18:41   #6
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
CHe errore ti da?
Poi non capisco come faccia a compilare. La prima funzione fa uso di una variabile chiamata P1, che localmente non esiste...
Ti consiglio di abilitare tutti gli Warning e di fermarti sempre, fino a che non sono risolti tutti.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2008, 19:00   #7
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ora funziona perfettamente

Codice HTML:
#include <stdio.h>
#include <stdlib.h>
#include "funzioni_pile.h"

pilaPtr Inverti(pilaPtr P){
        
        pilaPtr P2=NULL;
        pilaPtr P3=NULL;
        int e=0;
        
        while((Empty(P))==0){
                             e=Top(P);
                             P2=Push(P2,e);
                             P3=Push(P3,e);
                             P=Pop(P);}
                             
        while((Empty(P2))==0){
                              e=Top(P2);
                              P=Push(P,e);
                              P2=Pop(P2);}
        
                              
        return P3;}
                             
        
        
int main(void){
    
    pilaPtr P1=NULL;
    pilaPtr P2=NULL;
    
    P1=Push(P1,1);
    P1=Push(P1,2);
    P1=Push(P1,3);
    
    printf("\n");
    
    Stampa(P1);
    
    printf("\n");
    
    P2=Inverti(P1);
    
    Stampa(P2);
    
    system("PAUSE");}
    
                             
                             
                             
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2008, 02:52   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
ora funziona perfettamente
A parte l'indentazione...
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
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...
Le analisi di ALMA sulla cometa interste...
La missione cinese Tianwen-3 per portare...
Un satellite di HEO Space ha catturato u...
Mini LED 144Hz a prezzo folle: questo Hi...
Novità per Fortinet: arrivano For...
Volkswagen e Xpeng, il SUV è real...
Volkswagen ribattezza ID.3 e le dà un mo...
Aruba rende disponibile VMware Hosted Pr...
Questa Olympus da 20 MP con stabilizzazi...
Il nuovo dispositivo di Rabbit si chiama...
'Se avete RAM, siamo pronti ad acquistar...
Veeam corregge diverse vulnerabilit&agra...
MacBook Neo segna una svolta per Apple: ...
Polestar pubblica il report LCA di Poles...
Il rame non basta più: NVIDIA, AM...
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: 03:10.


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