Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
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 ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-05-2009, 11:04   #1
ivan p
Member
 
Iscritto dal: Jun 2008
Messaggi: 58
[Linguaggio C] Aiuto interpretazione lista

Salve, studio ingegneria informatica e ho qualche problema ad interpretare il codice di un esempio di lista del mio prof; Utilizzo il devc++. Sarò grato a tutti coloro che potranno aiutarmi.

Quello che non capisco è il funzionamento della funzione Full quando viene richiamata nel Main.

#include <stdio.h>
#include <malloc.h>
#define LISTAVUOTA NULL

typedef int tipobase;

typedef short boolean;

typedef struct nodo {
tipobase info;
struct nodo *next;
} *list;

typedef list position;

position End(list l)
{
if (l==LISTAVUOTA) return(LISTAVUOTA);
while (l->next!=LISTAVUOTA)
l=l->next;
return(l);
}

position First(list l)
{
return(LISTAVUOTA); /*se la lista è vuota torna END(l) */
}

void MakeNull(list *l)
{
*l=LISTAVUOTA;
}

boolean Empty(list l)
{
return(l==LISTAVUOTA);
}

boolean Full(list l)
{
return(0);
}

void Insert(list *l, position p, tipobase x)
{
struct nodo * temp;

temp=(struct nodo *) malloc(sizeof(struct nodo));
temp->info=x;
if (p==LISTAVUOTA) {
temp->next=*l;
*l=temp;
} else {
temp->next=p->next;
p->next=temp;
}
}

void Delete(list *l, position p)
{
struct nodo * tmp;

if (!Empty(*l) && p!=End(*l)) {
if (p==LISTAVUOTA) {
tmp=(*l)->next;
free (*l);
*l=tmp;
} else {
tmp=p->next;
p->next=tmp->next;
free (tmp);
}
}
}

position Locate(list l, tipobase x)
{

if (!Empty(l)) {
if (l->info==x) return(LISTAVUOTA);
while (l->next!=LISTAVUOTA) {
if (l->next->info==x) return(l);
l=l->next;
}
return(l);
}
}

tipobase Retrieve(list l, position p)
{
if (!Empty(l) && p!=End(l)) {
if (p==LISTAVUOTA) return(l->info);
else return(p->next->info);
}
}

position Next(list l, position p)
{
if (p!=End(l)) {
if (p==LISTAVUOTA) return(l);
else return(p->next);
}
}

void visita(list l)
{
position p,u;
tipobase x;
int i=0;

p=First(l);
u=End(l);
while (p!=u) {
x=Retrieve(l,p);
printf("L'elemento di posizione %d e' %d \n",++i,x);
p=Next(l,p);
}
}

void insord(list *l, tipobase x)
{
position p,u;
tipobase tmp;

if (Empty(*l)) Insert(l,First(*l),x);
else {
p=First(*l);
u=End(*l);
while (p!=u) {
tmp=Retrieve(*l,p);
if (tmp<x)
p=Next(*l,p);
else break;
}
Insert(l,p,x);
}
}

main()
{
list lt; //Variabile locale Lista
int s;
tipobase elem;
position pos;

MakeNull(&lt);

do {
printf("Menu di Operazioni \n");
printf("1-Inserimento Ordinato \n");
printf("2-Ricerca \n");
printf("3-Cancellazione \n");
printf("4-Visita Lista \n");
printf("5-Fine \n");
printf("Inserisci la scelta ---> ");
scanf("%d",&s);
fflush(stdin);
switch(s) {

case 1 : {
if (Full(lt)) printf("Lista piena \n");
else {
printf("Inserisci l'Elemento da Inserire ");
scanf("%d",&elem);
fflush(stdin);
insord(&lt,elem);
}
break;
}
case 2 : {
if (Empty(lt)) printf("Lista Vuota \n");
else {
printf("Inserisci l'Elemento da Ricercare \n");
scanf("%d",&elem);
fflush(stdin);
pos=Locate(lt,elem);
if (pos!=End(lt))
printf("Elemento Trovato \n");
else printf("Elemento non Trovato \n");
}
break;
}
case 3 : {
if (Empty(lt)) printf("Lista Vuota \n");
else {
printf("Inserisci l'Elemento da Cancellare \n");
scanf("%d",&elem);
fflush(stdin);
pos=Locate(lt,elem);
if (pos!=End(lt)) {
Delete(&lt,pos);
printf("Elemento Cancellato \n");
}
else printf("Elemento non Trovato \n");
}
break;
}
case 4 : {
if (Empty(lt)) printf("Lista Vuota \n");
else visita(lt);
break;
}
}
} while (s<5);
}
ivan p è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2009, 11:08   #2
ivan p
Member
 
Iscritto dal: Jun 2008
Messaggi: 58
Scusate mi sono accorto che incollando il codice la formattazione del testo è andata a farsi benedire, spero possiate aiutarmi comunque.

Ultima modifica di ivan p : 30-05-2009 alle 11:28.
ivan p è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2009, 13:14   #3
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
Quote:
Originariamente inviato da ivan p Guarda i messaggi
Salve, studio ingegneria informatica e ho qualche problema ad interpretare il codice di un esempio di lista del mio prof; Utilizzo il devc++. Sarò grato a tutti coloro che potranno aiutarmi.

Quello che non capisco è il funzionamento della funzione Full quando viene richiamata nel Main.
Codice:
#include <stdio.h> 
#include <malloc.h> 
#define LISTAVUOTA NULL 

typedef int tipobase; 

typedef short boolean; 

typedef struct nodo { 
     tipobase info; 
     struct nodo *next; 
} *list; 

typedef list position; 

position End(list l) 
{ 
 if (l==LISTAVUOTA) return(LISTAVUOTA); 
 while (l->next!=LISTAVUOTA) 
               l=l->next; 
 return(l); 
} 

position First(list l) 
{ 
  return(LISTAVUOTA); /*se la lista è vuota torna END(l) */ 
} 

void MakeNull(list *l) 
{ 
  *l=LISTAVUOTA; 
} 

boolean Empty(list l) 
{ 
 return(l==LISTAVUOTA); 
} 

boolean Full(list l) 
{ 
 return(0); 
} 

void Insert(list *l, position p, tipobase x) 
{ 
  struct nodo * temp; 

  temp=(struct nodo *) malloc(sizeof(struct nodo)); 
   temp->info=x; 
    if (p==LISTAVUOTA) { 
      temp->next=*l; 
     *l=temp; 
    } else { 
           temp->next=p->next; 
           p->next=temp; 
    } 
 } 

void Delete(list *l, position p) 
 { 
    struct nodo * tmp; 

    if (!Empty(*l) && p!=End(*l)) { 
           if (p==LISTAVUOTA) { 
                     tmp=(*l)->next; 
                     free (*l); 
                     *l=tmp; 
           } else { 
                     tmp=p->next; 
                     p->next=tmp->next; 
                     free (tmp); 
           } 
    } 
 } 

position Locate(list l, tipobase x) 
 { 

 if (!Empty(l)) { 
           if (l->info==x) return(LISTAVUOTA); 
           while (l->next!=LISTAVUOTA) { 
                     if (l->next->info==x) return(l); 
                     l=l->next; 
           } 
           return(l); 
 } 
 } 

tipobase Retrieve(list l, position p) 
 { 
    if (!Empty(l) && p!=End(l)) { 
           if (p==LISTAVUOTA) return(l->info); 
           else return(p->next->info); 
    } 
 } 

position Next(list l, position p) 
 { 
 if (p!=End(l)) { 
     if (p==LISTAVUOTA) return(l); 
     else return(p->next); 
  } 
 } 

void visita(list l) 
{ 
 position p,u; 
  tipobase x; 
 int i=0; 

 p=First(l); 
 u=End(l); 
 while (p!=u) { 
    x=Retrieve(l,p); 
   printf("L'elemento di posizione %d e' %d \n",++i,x); 
   p=Next(l,p); 
 } 
} 

void insord(list *l, tipobase x) 
{ 
   position p,u; 
   tipobase tmp; 

   if (Empty(*l)) Insert(l,First(*l),x); 
   else { 
          p=First(*l); 
          u=End(*l); 
          while (p!=u) { 
                  tmp=Retrieve(*l,p); 
                   if (tmp<x) 
                                  p=Next(*l,p); 
                   else break; 
          } 
          Insert(l,p,x); 
   } 
} 

main() 
{ 
    list lt;  //Variabile locale Lista 
    int s; 
    tipobase elem; 
   position pos; 

   MakeNull(&lt); 

    do { 
         printf("Menu di Operazioni \n"); 
         printf("1-Inserimento Ordinato \n"); 
         printf("2-Ricerca \n"); 
         printf("3-Cancellazione \n"); 
         printf("4-Visita Lista \n"); 
         printf("5-Fine \n"); 
         printf("Inserisci la scelta ---> "); 
         scanf("%d",&s); 
         fflush(stdin); 
         switch(s) { 

         case 1 : { 
                 if (Full(lt)) printf("Lista piena \n"); 
                 else { 
                     printf("Inserisci l'Elemento da Inserire "); 
                     scanf("%d",&elem); 
                     fflush(stdin); 
                     insord(&lt,elem); 
              } 
              break; 
       } 
       case 2 : { 
              if (Empty(lt)) printf("Lista Vuota \n"); 
              else { 
                     printf("Inserisci l'Elemento da Ricercare \n"); 
                     scanf("%d",&elem); 
                     fflush(stdin); 
                     pos=Locate(lt,elem); 
                     if (pos!=End(lt)) 
                            printf("Elemento Trovato \n"); 
                     else printf("Elemento non Trovato \n"); 
              } 
              break; 
       } 
       case 3 : { 
              if (Empty(lt)) printf("Lista Vuota \n"); 
              else { 
                     printf("Inserisci l'Elemento da Cancellare \n"); 
                     scanf("%d",&elem); 
                     fflush(stdin); 
                     pos=Locate(lt,elem); 
                     if (pos!=End(lt)) { 
                            Delete(&lt,pos); 
                            printf("Elemento Cancellato \n"); 
                     } 
                     else printf("Elemento non Trovato \n"); 
              } 
              break; 
       } 
       case 4 : { 
              if (Empty(lt)) printf("Lista Vuota \n"); 
              else visita(lt); 
              break; 
       } 
       } 
   } while (s<5); 
}
usa il tag code la prossima volta
secondo me c'è qualcosa di sbagliato, li passa un argomento e non lo usa. inoltre non può ritornare sempre zero altrimenti quell'if-else è inutile.

Ultima modifica di ndakota : 30-05-2009 alle 13:19.
ndakota è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2009, 13:53   #4
ivan p
Member
 
Iscritto dal: Jun 2008
Messaggi: 58
Quale argomento non usa? Per quello che ho capito quando il main esamina la condizione la funzione restituisce sempre che la lista non è mai piena e questo non sarebbe corretto perchè può riempirsi. Giusto?
ivan p è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2009, 13:56   #5
||ElChE||88
Senior Member
 
Iscritto dal: Dec 2003
Messaggi: 4907
Se la dimensione della lista non è limitata come fa a diventare piena?
||ElChE||88 è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2009, 14:02   #6
ivan p
Member
 
Iscritto dal: Jun 2008
Messaggi: 58
Giusto.
ivan p è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2009, 14:03   #7
ivan p
Member
 
Iscritto dal: Jun 2008
Messaggi: 58
Altro dubbio, perchè Firtst restituisce sempre NULL? Perchè anche Empty restituisce NULL?

Ultima modifica di ivan p : 30-05-2009 alle 14:15.
ivan p è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2009, 15:02   #8
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2783
Perché ritorna LISTAVUOTA che hai definito all'inizio come NULL.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 30-05-2009, 16:40   #9
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
Quote:
Originariamente inviato da ivan p Guarda i messaggi
Quale argomento non usa? Per quello che ho capito quando il main esamina la condizione la funzione restituisce sempre che la lista non è mai piena e questo non sarebbe corretto perchè può riempirsi. Giusto?
quello della funzione Full()
ndakota è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Il MacBook Pro è sempre più...
Il prezzo della Switch 2 potrebbe divent...
TikTok chiarisce il funzionamento della ...
Samsung Galaxy A07 5G: il nuovo entry le...
Realme 16 in arrivo: un mix tra iPhone A...
Domenica di follia su Amazon: iPhone 17 ...
Questo portatile HP OMEN con Core Ultra ...
Robot aspirapolvere al prezzo giusto: le...
Il nuovo M5 Max potrebbe avere una GPU p...
Pulizie automatiche al top (e a prezzo B...
Casa più calda, spese più leggere: Tado ...
Mini PC mostruoso in offerta nascosta su...
Netflix promette 45 giorni di esclusivit...
Gigabyte: un handheld? Sì, ma sol...
Samsung conferma l'arrivo di tre variant...
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: 07:42.


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