Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Basato su piattaforma Qualcomm Snapdragon X Plus a 8 core, il nuovo Microsoft Surface Pro 12 è un notebook 2 in 1 molto compatto che punta sulla facilità di trasporto, sulla flessibilità d'uso nelle differenti configurazioni, sul funzionamento senza ventola e sull'ampia autonomia lontano dalla presa di corrente
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet!
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet!
Il REDMAGIC Astra Gaming Tablet rappresenta una rivoluzione nel gaming portatile, combinando un display OLED da 9,06 pollici a 165Hz con il potente Snapdragon 8 Elite e un innovativo sistema di raffreddamento Liquid Metal 2.0 in un form factor compatto da 370 grammi. Si posiziona come il tablet gaming più completo della categoria, offrendo un'esperienza di gioco senza compromessi in mobilità.
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2
Dopo un mese di utilizzo intensivo e l'analisi di oltre 50 scatti, l'articolo offre una panoramica approfondita di Nintendo Switch 2. Vengono esaminate le caratteristiche che la definiscono, con un focus sulle nuove funzionalità e un riepilogo dettagliato delle specifiche tecniche che ne determinano le prestazioni
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-02-2010, 10:40   #1
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
[C] Help pseudo stack

Salve ragazzi...sto cercando di fare un programmino semplice che svolge il ruolo di trattare la memoria con la medesima politica di uno stack col linguaggio C....chiaramente mi limito solo alle operazioni push e pop ed eventuale falimento di queste...solo che l'output chiaramente non mi torna ( uso dev c++)

il codice è questo:

Codice:
//Inclusioni
#include <stdio.h>
#include <stdlib.h>
#include <locale.h>

//Definizioni per l'uso dei booleani
typedef unsigned short int Boolean;
#define TRUE 1
#define FALSE 0


struct stack{
       int size;
       int TOS;
       float * buffer;
       };
Boolean push(struct stack * ptr, float value);
Boolean pop(struct stack * ptr, float*value_ptr);
void get_value(float *value_ptr);
void print_value(float value);
void notify_push_failure(void); 
void notify_pop_failure(void);  
int init ( struct stack * ptr, int size);
int get_size(int*size_ptr);    
        
int main (void)
{
     struct stack stack;
     int size;
     float value;
     Boolean exit;
     Boolean result;
     init(&stack,size);
     get_size (&size);
     
     do{
          exit=FALSE;
          printf("\nPremi A se vuoi inserire un valore nello stack, B se vuoi estrarre un valore, X se vuoi uscire:\n");
     
          char selection;
          selection=getchar();
          switch(selection)
          {
                   case 'A':
                        get_value(&value);
                        result= push(&stack,value);
                        if (result==FALSE)
                        notify_push_failure();
                   break;
                   
                   case 'B':  
                         result= pop(&stack,&value);
                         if(result==TRUE)
                         print_value(value);
                         else
                         notify_pop_failure();
                   break;
                   
                   case'X':
                           exit=TRUE; 
                           break;
                           
                   default  :  printf ("\nHai digitato un carattere diverso dai caratteri: A,B,X\n");
        
          }
     
     } while(exit==FALSE && getchar()!=EOF );
    
     system("PAUSE");
}

int get_size(int*size_ptr)
{
     printf("\n Dimensione stack:\n");
     scanf("%d", &size_ptr);
}

int init ( struct stack * ptr, int size)
{
     ptr->size=size;
     ptr->TOS=0;
     ptr->buffer=(float*)malloc(size*sizeof(float));
}

Boolean push(struct stack * ptr, float value)
// se il buffer non è pieno allora restituisce TRUE
{
        if(ptr->TOS<ptr->size)
        {
             
            (ptr->buffer)[ptr->TOS]=value;
            (ptr->TOS)++;
            return TRUE;
        }
        else
        return FALSE;
}

Boolean pop( struct stack * ptr, float*value_ptr)
{
        if(ptr->TOS>0)
        {
              (ptr->TOS)--;
              *value_ptr=(ptr->buffer)[ptr->TOS];
              return TRUE;
        }
        else
               return FALSE;
                 
}        

void get_value(float*value_ptr)
// acquisisce un valore float da tastiera
{
              printf("\n Inserisci un valore");
              scanf("%f%, &value_ptr");
}

void print_value(float value)
{
     printf("\n Il valore estratto\x8A:%f", value);
}

void notify_push_failure(void)
{ 
     printf("\n Il buffer \x8A pieno. Impossibile inserire il valore!\n");
     
}

void notify_pop_failure(void)
{
     printf("\n Il buffer \x8A vuoto. Impossibile estrarre il valore!\n");
      
}
nell'output mi stampa a video due volte la stessa frase poi se richiedo l'operazione di pop mi crasha il programma...

Grazie mille gia da adesso
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 14:11   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
Ho corretto buona parte degli errori, ho segnato in rosso le correzioni:
Codice:
//Inclusioni
#include <stdio.h>
#include <stdlib.h>
#include <locale.h>

//Definizioni per l'uso dei booleani
typedef unsigned short int Boolean;
#define TRUE 1
#define FALSE 0


struct stack{
       int size;
       int TOS;
       float * buffer;
       };
Boolean push(struct stack * ptr, float value);
Boolean pop(struct stack * ptr, float*value_ptr);
void get_value(float *value_ptr);
void print_value(float value);
void notify_push_failure(void);
void notify_pop_failure(void);
int init ( struct stack * ptr, int size);
int get_size(int*size_ptr);

int main (void)
{
     struct stack stack;
     int size;
     float value;
     Boolean exit;
     Boolean result;
     get_size (&size);
     init(&stack,size);

     do{
          exit=FALSE;
          printf("\nPremi A se vuoi inserire un valore nello stack, B se vuoi estrarre un valore, X se vuoi uscire:\n");

          char selection;
          selection=getchar();
          switch(selection)
          {
                   case 'A':
                        get_value(&value);
                        result= push(&stack,value);
                        if (result==FALSE)
                        notify_push_failure();
                   break;

                   case 'B':
                         result= pop(&stack,&value);
                         if(result==TRUE)
                         print_value(value);
                         else
                         notify_pop_failure();
                   break;

                   case'X':
                           exit=TRUE;
                           break;

                   default  :  printf ("\nHai digitato un carattere diverso dai caratteri: A,B,X\n");

          }

     } while(exit==FALSE && getchar()!=EOF );

     system("PAUSE");
}

int get_size(int*size_ptr)
{
     printf("\n Dimensione stack:\n");
     scanf("%d", size_ptr);
}

int init ( struct stack * ptr, int size)
{
     ptr->size=size;
     ptr->TOS=0;
     ptr->buffer=(float*)malloc(size*sizeof(float));
}

Boolean push(struct stack * ptr, float value)
// se il buffer non è pieno allora restituisce TRUE
{
        if(ptr->TOS<ptr->size)
        {
            (ptr->buffer)[ptr->TOS]=value;
            (ptr->TOS)++;
            return TRUE;
        }
        else
        return FALSE;
}

Boolean pop( struct stack * ptr, float*value_ptr)
{
        if(ptr->TOS>0)
        {
              (ptr->TOS)--;
              *value_ptr=(ptr->buffer)[ptr->TOS];
              return TRUE;
        }
        else
               return FALSE;

}

void get_value(float*value_ptr)
// acquisisce un valore float da tastiera
{
              printf("\n Inserisci un valore");
              scanf("%f", value_ptr);
}

void print_value(float value)
{
     printf("\n Il valore estratto\x8A:%f", value);
}

void notify_push_failure(void)
{
     printf("\n Il buffer \x8A pieno. Impossibile inserire il valore!\n");

}

void notify_pop_failure(void)
{
     printf("\n Il buffer \x8A vuoto. Impossibile estrarre il valore!\n");

}
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 14:59   #3
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
Grazie per le correzioni...io pensavo che la & nello scanf ci dovesse sempre essere, solo che cmq non mi torna:
non mi da errori durante la compilazione solo che nella finestra di output inserisco la dimensione e subito dopo mi compare la scritta che dice che non ho premuto nessuno tra i tasti A,B,X.. poi premo ad es. A e mi ridice che non ho digitato i tasti giusti
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 18:16   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
La & in genere si usa nello scanf perché si fa un passaggio di parametro per indirizzo (in modo da ritrovare nella variabile il valore inserito dopo la chiamata a scanf) ma nel tuo caso il parametro è un puntatore p, quindi è già un indirizzo, e quindi & non serve (il valore letto si troverà in *p).
L'altro problema è dovuto all'uso che fai di getchar() e dal suo comportamento:
- ogni volta che richiami getchar() viene letto un caratter dal buffer di input
- il carattere di ritorno a capo non viene scartato da getchar()

Quindi per schematizzare l'esecuzione:
1. Richiedi l'immissione della dimensione dello stack
2. L'utente inserisce un valore e digita invio
//Nel buffer avrai "int\n"
3. Leggi un intero dal buffer
//Nel buffer avrai "\n"
4. Leggi un carattere dal buffer per la scelta tra A,B,X
//Viene letto '\n', ora il buffer è vuoto
5. Viene raggiunta la condizione del while (dove usi nuovamente getchar())
6. L'utente digita ad esempio A e invio
//Nel buffer hai "A\n"
7. Il getchar della condizione del while consuma A
//Nel buffer hai "\n"
8. Torni al punto 4.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 18:19   #5
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
intanto ho messo uno scanf prima della getchar() ed è migliorato solo che dopo per qualche errore mi crasha la finestra di output

quindi come dovrei rimediare?
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 18:42   #6
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
Io aggiungerei un case per ignorare '\n' (l'invio), poi userei selection nella condizione del while al posto della getchar() e infine non stamperei il messaggio che chiedere l'immissione dell'input quando selection=='\n'
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 22:32   #7
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Io aggiungerei un case per ignorare '\n' (l'invio), poi userei selection nella condizione del while al posto della getchar() e infine non stamperei il messaggio che chiedere l'immissione dell'input quando selection=='\n'
come faccio a ignorare l'invio?
come modifico il while?
come deve essere il codice quindi?
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 22:38   #8
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
Mi sembra che ti ho già detto tutto quello che serve per risolvere il problema da solo, non hai interesse a capire quello che stai studiando?
L'unica cosa poco chiara potrebbe essere ignorare l'invio: per far questo aggiungi un case per il carattere '\n' e ci metti solo un break.
Ad ogni modo scusa se ho frainteso.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 22:56   #9
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
si ok ma non capisco il senso! il motivo cè che getchar() prendeo INVIO come carattere? se si in che modo?

case: '\n'
break;


e basta oppure una cosa:

int invio;
printf(" - Premi INVIO per continuare - \n");
invio = getchar();[/b]

poi nn capisco il senso del punto 6 del tuo intervento di prima. In che senso ho A nel buffer?
io voglio digitare n numeri dove n=sizeofbuffer e quindi avrò solo numeri nel buffer e non caratteri...
cmq nn ho capito bene quello che mi dici e se ti sta fatica correggermi il codice nn importa..pace, ma fatto sta che per ora non torna molto bene!!!


per ora il codiece è così:
Codice:
//Inclusioni
#include <stdio.h>
#include <stdlib.h>


//Definizioni per l'uso dei booleani
typedef unsigned short int Boolean;
#define TRUE 1
#define FALSE 0


struct stack{
       int size;
       int TOS;
       float * buffer;
       };
Boolean push(struct stack * ptr, float value);
Boolean pop(struct stack * ptr, float*value_ptr);
void get_value(float *value_ptr);
void print_value(float value);
void notify_push_failure(void); 
void notify_pop_failure(void);  
int init ( struct stack * ptr, int size);
int get_size(int*size_ptr);  
int getchar (void);
  
        
int main (void)
{
     struct stack stack;
     int size;
     float value;
     Boolean exit;
     Boolean result;
     get_size (&size);
     init(&stack,size);
     
     
     do{
          exit=FALSE;
          printf("\nPremi A se vuoi inserire un valore nello stack, B se vuoi estrarre un valore, X se vuoi uscire:\n");
          
     
          char selection;
         int invio;
          selection=getchar();
          scanf("%c", &selection);
          switch(selection)
          {
                   case '\n':
                        printf( " Inserisci un valore");        
                   case 'A':
                   case 'a':
                        get_value(&value);
                        result = push(&stack,value);
                        if (result==FALSE)
                        notify_push_failure();
                       
                   break;
                   
                   case 'B':
                   case 'b':  
                         result= pop(&stack,&value);
                         if(result==TRUE)
                         print_value(value);
                         else
                         notify_pop_failure();
                   break;
                   
                   case'X':
                   case'x':        
                           exit=TRUE; 
                           break;
                           
                   default  :  printf ("\nHai digitato un carattere diverso dai caratteri: A,B,X\n");
        
          }
     
     } while(exit==FALSE && getchar()!=EOF );
    
     system("PAUSE");
}

int get_size(int*size_ptr)
{
     printf("\n Dimensione stack:");
     scanf("%d", size_ptr);
}

int init ( struct stack * ptr, int size)
{
     ptr->size=size;
     ptr->TOS=0;
     ptr->buffer=(float*)malloc(size*sizeof(float));
}

Boolean push(struct stack * ptr, float value)
// se il buffer non è pieno allora restituisce TRUE
{
        if(ptr->TOS<ptr->size)
        {
             
            (ptr->buffer)[ptr->TOS]=value;
            (ptr->TOS)++;
            return TRUE;
        }
        else
        return FALSE;
}

Boolean pop( struct stack * ptr, float*value_ptr)
{
        if(ptr->TOS>0)
        {
              (ptr->TOS)--;
              *value_ptr=(ptr->buffer)[ptr->TOS];
              return TRUE;
        }
        else
               return FALSE;
                 
}        

void get_value(float*value_ptr)
// acquisisce un valore float da tastiera
{
              printf("\n Inserisci un valore");
              scanf("%f%", value_ptr);
}

void print_value(float value)
{
     printf("\n Il valore estratto \x8A:%f", value);
}

void notify_push_failure(void)
{ 
     printf("\n Il buffer \x8A pieno. Impossibile inserire il valore!\n");
     
}

void notify_pop_failure(void)
{
     printf("\n Il buffer \x8A vuoto. Impossibile estrarre il valore!\n");
      
}
E non torna!!!
grazie
__________________
Ho concluso felicemente molte trattative su questo forum!

Ultima modifica di Solido : 23-02-2010 alle 23:01.
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 23:13   #10
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
intanto nel while ho messto getchar()!='\n'
solo che nn mi fa inserire + di un carattere nel push
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 23:23   #11
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
Quote:
Originariamente inviato da Solido Guarda i messaggi
si ok ma non capisco il senso! il motivo cè che getchar() prendeo INVIO come carattere? se si in che modo?
Non ho capito qual è il tuo dubbio
Quote:
Originariamente inviato da Solido Guarda i messaggi
poi nn capisco il senso del punto 6 del tuo intervento di prima. In che senso ho A nel buffer?
Riporto qui il punto 6:
6. L'utente digita ad esempio A e invio
//Nel buffer hai "A\n"
Nel buffer va a finire quello che hai digitato, se digiti A e poi premi invio nel buffer avrai il carattere 'A' seguito da '\n' che è la codifica del ritorno a capo
Quote:
Originariamente inviato da Solido Guarda i messaggi
io voglio digitare n numeri dove n=sizeofbuffer e quindi avrò solo numeri nel buffer e non caratteri...
Il programma ti chiede di digitare un valore da inserire nello stack solo in seguito alla scelta A, io ti stavo spiegando perché non riesci ad entrare in quella scelta (e neanche nelle altre).
Quote:
Originariamente inviato da Solido Guarda i messaggi
cmq nn ho capito bene quello che mi dici e se ti sta fatica correggermi il codice nn importa..pace, ma fatto sta che per ora non torna molto bene!!!
Quello che chiedi va oltre i limiti del regolamento (darti il codice corretto e via). Io sto tentando di spiegarti come risolvere i problemi in modo che tu possa imparare qualcosa.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 23:28   #12
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
Hai ragione solo che nn capisco come rigirare quella porzione di codice...capisco di avere il problema sul push ma nn riesco a risoleverlo
adesso avevo provato con un while nel case A ma lo ripiena senz che ci possa mattere le mani

case 'A':
case 'a':
while(result==TRUE){
get_value(&value);
result = push(&stack,value);}

notify_push_failure();



break;

per quando riguarda la mia prima affermazione chiedo solo a cosa mi serva fare in quel modo... se nn scrivo quello che dici la funzione getchar prende "l'invio" come un carattere acquisito da tastiera?
cmq ora nn mi da + problemi sull'acquisizione del carattere...
solo che col while ripiena il buffer senza darmi la possibilità di inserire valori nonostante richiami la get value
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 23:35   #13
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
Quote:
Originariamente inviato da Solido Guarda i messaggi
Hai ragione solo che nn capisco come rigirare quella porzione di codice...capisco di avere il problema sul push ma nn riesco a risoleverlo
adesso avevo provato con un while nel case A ma lo ripiena senz che ci possa mattere le mani

case 'A':
case 'a':
while(result==TRUE){
get_value(&value);
result = push(&stack,value);}

notify_push_failure();



break;
In che senso lo riempie senza poterci mettere le mani?
Quote:
Originariamente inviato da Solido Guarda i messaggi
per quando riguarda la mia prima affermazione chiedo solo a cosa mi serva fare in quel modo... se nn scrivo quello che dici la funzione getchar prende "l'invio" come un carattere acquisito da tastiera?
Esatto, quindi la mia idea era quella di ignorarlo, e per far questo un case vuoto mi sembrava la cosa migliore.
Codice:
case '\n':
  break;
Quote:
Originariamente inviato da Solido Guarda i messaggi
cmq ora nn mi da + problemi sull'acquisizione del carattere...
solo che col while ripiena il buffer senza darmi la possibilità di inserire valori nonostante richiami la get value
Potresti postare il codice a cui stai facendo riferimento ora? Così lo provo anch'io e tento di capire cosa non va
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 23:37   #14
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
il codice di ora è così:

Codice:
//Inclusioni
#include <stdio.h>
#include <stdlib.h>


//Definizioni per l'uso dei booleani
typedef unsigned short int Boolean;
#define TRUE 1
#define FALSE 0


struct stack{
       int size;
       int TOS;
       float * buffer;
       };
Boolean push(struct stack * ptr, float value);
Boolean pop(struct stack * ptr, float*value_ptr);
void get_value(float *value_ptr);
void print_value(float value);
void notify_push_failure(void); 
void notify_pop_failure(void);  
int init ( struct stack * ptr, int size);
int get_size(int*size_ptr);  
int getchar (void);
  
        
int main (void)
{
     struct stack stack;
     int size;
     float value;
     Boolean exit;
     Boolean result;
     get_size (&size);
     init(&stack,size);
     
     
     do{
          exit=FALSE;
          printf("\nPremi A se vuoi inserire un valore nello stack, B se vuoi estrarre un valore, X se vuoi uscire:\n");
          
     
          char selection;
          selection=getchar();
          scanf("%c", &selection);
          switch(selection)
          {
                        
                   case 'A':
                   case 'a':
                        while(result==TRUE){
                        get_value(&value);
                        result = push(&stack,value);}
           
                        notify_push_failure();
                        
                        
                       
                   break;
                   
                   case 'B':
                   case 'b':  
                         result= pop(&stack,&value);
                         if(result==TRUE)
                         print_value(value);
                         else
                         notify_pop_failure();
                   break;
                   
                   case'X':
                   case'x':        
                           exit=TRUE; 
                           break;
                           
                   default  :  printf ("\nHai digitato un carattere diverso dai caratteri: A,B,X\n");
        
          }
     
     } while(exit==FALSE && getchar()!=EOF &&getchar()!='\n' );
    
     system("PAUSE");
}

int get_size(int*size_ptr)
{
     printf("\n Dimensione stack:");
     scanf("%d", size_ptr);
}

int init ( struct stack * ptr, int size)
{
     ptr->size=size;
     ptr->TOS=0;
     ptr->buffer=(float*)malloc(size*sizeof(float));
}

Boolean push(struct stack * ptr, float value)
// se il buffer non è pieno allora restituisce TRUE
{
        if(ptr->TOS<ptr->size)
        {
             
            (ptr->buffer)[ptr->TOS]=value;
            (ptr->TOS)++;
            return TRUE;
        }
        else
        return FALSE;
}

Boolean pop( struct stack * ptr, float*value_ptr)
{
        if(ptr->TOS>0)
        {
              (ptr->TOS)--;
              *value_ptr=(ptr->buffer)[ptr->TOS];
              return TRUE;
        }
        else
               return FALSE;
                 
}        

void get_value(float*value_ptr)
// acquisisce un valore float da tastiera
{
              printf("\n Inserisci un valore");
              scanf("%f%", value_ptr);
}

void print_value(float value)
{
     printf("\n Il valore estratto \x8A:%f", value);
}

void notify_push_failure(void)
{ 
     printf("\n Il buffer \x8A pieno. Impossibile inserire il valore!\n");
     
}

void notify_pop_failure(void)
{
     printf("\n Il buffer \x8A vuoto. Impossibile estrarre il valore!\n");
      
}

dimmi a te che problema da... a me quando digito A per fare push mi ripiena da solo il buffer:mc:
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2010, 23:51   #15
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
E' perché non hai inizializzato result a FALSE, quindi non entra nel while. Oppure puoi usare un do-while, così il test del while viene fatto dopo aver provato almeno un inserimento.
Riguardo la condizione del while più esterno io consigliavo di fare
Codice:
while(exit==FALSE && selection!=EOF);
In questo modo non vengono fatti altri getchar() inutili che potrebbero dare problemi. Resterebbe da ignorare l'invio ma ti ho già spiegato una possibile soluzione.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2010, 00:05   #16
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
Grazie!!!apparte che per entrare nel while result dovrà essere TRUE
cmq per quanto riguarda il selection ci avevo gia provato ma mi da errore

adesso il push funziona fino a buffer pieno solo che ora arrivato infondo al push mi dice di premere il tasto per continuare...e si chiude!
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2010, 00:18   #17
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
Quote:
Originariamente inviato da Solido Guarda i messaggi
Grazie!!!apparte che per entrare nel while result dovrà essere TRUE
cmq per quanto riguarda il selection ci avevo gia provato ma mi da errore

adesso il push funziona fino a buffer pieno solo che ora arrivato infondo al push mi dice di premere il tasto per continuare...e si chiude!
Penso sia per colpa di quel getchar()!='\n' nella condizione del while più esterno.
Che errore ti da mettendo il selection nella condizione del while invece del getchar?
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2010, 00:21   #18
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
mi dice che selection nn è dichiarato in quella funzione...e per quanto riguarda l'impossibilità di continuare dopo che il buffer si è pienato?
ccioè io faccio push fino a che nn si riempie solo che dopo nn mi da la possibilità di fare pop
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2010, 00:26   #19
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2773
Ah, ho capito, ti dice che selection non è visibile perché è dichiarata in un blocco diverso. Basta che sposti la dichiarazione di selection prima del do-while per risolvere quel problema.
Esce subito dopo aver finito i push perché quel getchar()!='\n' nella condizione del while legge l'invio dal buffer di input e quindi esce.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2010, 00:37   #20
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
risolto il selection ora resta quel getchar nel while che mi serve altrimenti mi scrive due volte la scritta:
Hai digitato un carattere diverso dai caratteri: A,B,X

grazie ancora
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso Microsoft Surface Pro 12 è il 2 in 1 pi&u...
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet! Recensione REDMAGIC Astra Gaming Tablet: che spe...
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2 Dopo un mese, e 50 foto, cosa abbiamo capito del...
Gigabyte Aero X16 Copilot+ PC: tanta potenza non solo per l'IA Gigabyte Aero X16 Copilot+ PC: tanta potenza non...
vivo X200 FE: il top di gamma si è fatto tascabile? vivo X200 FE: il top di gamma si è fatto ...
Crollano di prezzo gli stupendi TV 4K OL...
Prodotti pericolosi su Temu e Shein: l'U...
JLR annuncia il ritardo del Range Rover ...
Stufi di tagliare il prato? Chi prova un...
Verso un vaccino universale contro il ca...
L'iPhone 17 Air con batteria 'mini' da m...
Iliad offre l'upgrade gratuito ai propri...
Sembra impossibile ma è scesa ancora: la...
Netflix: ecco tutti i titoli ''shock'' i...
Altman, OpenAI: 'Supereremo quota 1 mili...
Sedie gaming con LED, massaggio e poggia...
OpenAI, l'IA conquista l'oro all'Olimpia...
FBC: Firebreak è un flop? I gioca...
Due robot Roborock al minimo storico: la...
Sfida tra laptop AI con schermo OLED: AS...
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: 11:11.


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