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 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


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...
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...
Tre robot Narwal in offerta: pulizia aut...
Gracenote denuncia OpenAI: ChatGPT addes...
Microsoft AI Tour Milano: dall'efficienz...
Asus ExpertBook Ultra: Intel Core Ultra ...
Intel presenta i processori desktop Core...
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: 01:25.


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